2

NSZombieEnabledがあるときにこのエラーを追跡しようとしています。NSFetchedResultsControllerを使用したEXC_BAD_ACCESS

フェッチされた結果コントローラがフェッチを実行しようとすると、EXC_BAD_ACCESSが返されます。

デバッガは言う:

-[CFNumber retain]: message sent to deallocated instance 0x6e88d10 

バックトレースは言う:

#0 0x014bbe1e in ___forwarding___() 
#1 0x014bbce2 in __forwarding_prep_0___() 
#2 0x0145c490 in CFRetain() 
#3 0x0147929a in CFNumberCreate() 
#4 0x00b221ed in -[NSPlaceholderNumber initWithShort:]() 
#5 0x00b2216a in +[NSNumber numberWithShort:]() 
#6 0x010a549e in snapshot_get_value_as_object() 
#7 0x010a2a41 in _sharedIMPL_pvfk_core() 
#8 0x010a707d in -[NSManagedObject(_PFDynamicAccessorsAndPropertySupport)   _genericValueForKey:withIndex:flags:]() 
#9 0x010df6f0 in _PF_Handler_Public_GetProperty() 
#10 0x010df61d in -[NSManagedObject valueForKey:]() 
#11 0x00aea8d5 in -[NSObject(NSKeyValueCoding) valueForKeyPath:]() 
#12 0x00b1ad5e in _NSSortFunctionMany() 
#13 0x0152bf3f in __CFMergeSortArray_block_invoke_0() 
#14 0x014b19d3 in __CFSimpleMergeSort() 
#15 0x014b1969 in __CFSimpleMergeSort() 
#16 0x014b1969 in __CFSimpleMergeSort() 
#17 0x014b1828 in CFSortIndexes() 
#18 0x014eb7e9 in CFMergeSortArray() 
#19 0x00b1828e in _sortedObjectsUsingDescriptors() 
#20 0x00b17fd9 in -[NSArray(NSKeyValueSorting) sortedArrayUsingDescriptors:]() 
#21 0x010853c6 in -[NSManagedObjectContext executeFetchRequest:error:]() 
#22 0x0118fc8f in -[NSFetchedResultsController performFetch:]() 
#23 0x000105c0 in -[RootViewController fetchedResultsController] (self=0x6d4bc80, _cmd=0x15a28) at /Users/david/Dropbox/Xcode/MyApp/MyApp/RootViewController.m:513 
#24 0x0000e549 in -[RootViewController reloadTableView] (self=0x6d4bc80, _cmd=0x158d6) at /Users/david/Dropbox/Xcode/MyApp/MyApp/RootViewController.m:159 
#25 0x01556ec9 in -[NSObject performSelector:withObject:withObject:]() 
#26 0x001dc5c2 in -[UIApplication sendAction:to:from:forEvent:]() 
#27 0x001dc55a in -[UIApplication sendAction:toTarget:fromSender:forEvent:]() 
#28 0x00281b76 in -[UIControl sendAction:to:forEvent:]() 
#29 0x0028203f in -[UIControl(Internal) _sendActionsForEvents:withEvent:]() 
#30 0x00281bab in -[UIControl sendActionsForControlEvents:]() 
#31 0x002cfa99 in -[UISegmentedControl _setSelectedSegmentIndex:notify:]() 
#32 0x002d1407 in -[UISegmentedControl touchesBegan:withEvent:]() 
#33 0x0020193f in -[UIWindow _sendTouchesForEvent:]() 
#34 0x00201c56 in -[UIWindow sendEvent:]() 
#35 0x001e8384 in -[UIApplication sendEvent:]() 
#36 0x001dbaa9 in _UIApplicationHandleEvent() 
#37 0x02442fa9 in PurpleEventCallback() 
#38 0x015291c5 in __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__() 
#39 0x0148e022 in __CFRunLoopDoSource1() 
#40 0x0148c90a in __CFRunLoopRun() 
#41 0x0148bdb4 in CFRunLoopRunSpecific() 
#42 0x0148bccb in CFRunLoopRunInMode() 
#43 0x02441879 in GSEventRunModal() 
#44 0x0244193e in GSEventRun() 
#45 0x001d9a9b in UIApplicationMain() 
#46 0x000020ed in main (argc=1, argv=0xbffff5e8) at  /Users/david/Dropbox/Xcode/MyApp/MyApp/main.m:14 

はここNSFetchedResultsControllerの該当コードです:私は理解することができ

- (NSFetchedResultsController *)fetchedResultsController 

{ 

    if (__fetchedResultsController != nil) 
{ 
    return __fetchedResultsController; 
} 

NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init]; 
NSEntityDescription *entity = [NSEntityDescription entityForName:kGestureEntity inManagedObjectContext:self.managedObjectContext]; 
[fetchRequest setEntity:entity]; 

[fetchRequest setFetchBatchSize:0]; 

// sort keys 
NSSortDescriptor *sortDescriptor1 = [[NSSortDescriptor alloc] initWithKey:kCategory ascending:YES]; 
NSSortDescriptor *sortDescriptor2 = [[NSSortDescriptor alloc] initWithKey:kOrder ascending:YES]; // THIS IS AN INT 16 IN THE CORE DATA MODEL 
NSArray *sortDescriptors = [[NSArray alloc] initWithObjects:sortDescriptor1, sortDescriptor2, nil]; 

[fetchRequest setSortDescriptors:sortDescriptors]; 

//filter for males or females by tab index 
//set the tabIndex so the fetchedResultsController knows which sex to filter 
NSUInteger tabIndex = self.appDelegate.tabBarController.selectedIndex; 
NSString *theSex = [NSString string]; 
if (tabIndex == 0) 
    theSex = vFemale; 
else 
    theSex = vMale; 

//determine if sitting or standing 
NSInteger segmentIndex = self.segmentedControl.selectedSegmentIndex; 
NSString *sittingOrStanding = [NSString string]; 
if (segmentIndex == 0) 
    sittingOrStanding = vSitting; 
else 
    sittingOrStanding = vStanding; 

NSPredicate *predicate = [NSPredicate predicateWithFormat:@"%K like %@ AND (%K like %@ OR %K like %@)", kSex, theSex, kSittingOrStanding, sittingOrStanding, kSittingOrStanding, vBothSittingAndStanding]; 
[fetchRequest setPredicate:predicate]; 

NSFetchedResultsController *aFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:self.managedObjectContext sectionNameKeyPath:kCategory cacheName:nil]; 
aFetchedResultsController.delegate = self; 
self.fetchedResultsController = aFetchedResultsController; 

NSError *error = nil; 
if (![self.fetchedResultsController performFetch:&error]) //THIS IS WHERE EXC_BAD_ACCESS HAPPENS 
    { 
    NSLog(@"Unresolved error %@, %@", error, [error userInfo]); 
} 
[aFetchedResultsController release]; 
[fetchRequest release]; 
[sortDescriptor1 release]; 
[sortDescriptor2 release]; 
[sortDescriptors release]; 

return __fetchedResultsController; 

}  

唯一の事は私のコアでkOrderプロパティですデータモデルはInt 16に設定されています。しかし、私は何が時期尚早であるか分かりませんこのCFNumberは、プライベートな方法で保持されているように見えます。どんな助けでも大歓迎です。

EDIT1:ヘッダファイル:

@property (nonatomic, retain) NSFetchedResultsController *fetchedResultsController; 

次に実施中:

@synthesize fetchedResultsController=__fetchedResultsController; 

EDIT2:明確にするために、私のアプリは、iOSの5

答えて

3

デバッガにNSZombieEnabledMallocStackLogging、およびguard mallocを設定します。

(gdb) info malloc-history 0x6e88d10 

がクラッシュの原因"message sent to deallocated instance"オブジェクトのアドレスで0x6e88d10を交換し、あなたがはるかに便利なスタックトレースを取得し、それはあなたを助ける必要があります。その後、あなたのアプリケーションがクラッシュしたときに、GDBコンソールでこれを入力します問題の原因となっているコードの正確な行を特定します。

See this article for more detailed instructions.

+0

これは素晴らしいヒントです!しかし、私のアプリがiOS 4で正常に動作することに気付きましたが、iOS 5でクラッシュしました.Xcode 4.2がまだNDAの下にあるかどうかはわかりませんが、これはバグかもしれません。 –

+0

残念ながら、ガードmallocはシミュレータ上でのみ動作します。 – ThomasW

0
でのiOS 4のみクラッシュでうまく働い

あなたは実際にfetchedResultsControllerを保持していますか?あなたのヘッダーでは、@property(nonatomic、retain)NSFetchedResultsController * fetchedResultsControllerのようなものを使用しますか? ?そうでない場合は、FRCの割り当てが解除され、CFNumberは、レスポンダチェーンの最後で発生しているオブジェクトに過ぎません。

+0

はい、保持されます。上記の編集を参照してください。 –

関連する問題