これはかなり一般的なワークフローのようで、理由がわからないという問題があります。行を提供する NSFetchedResultsController を備えた UITableView があります。新しいオブジェクトを追加するには、コンテキストに挿入し、新しいビュー コントローラーを提示して詳細を編集します。ボタンの追加アクションは次のようになります。
-(IBAction)addNewIssueType:(id)sender
{
IssueType *newUntitledType = [NSEntityDescription insertNewObjectForEntityForName:@"IssueType" inManagedObjectContext:self.managedObjectContext];
newUntitledType.name = NSLocalizedString(@"Untitled Task", @"Name for newly created task");
[self saveContext];
self.editingType = newUntitledType;
[self presentNameEditViewForType:newUntitledType];
}
saveContext メソッドで例外が発生してクラッシュしています。エラー:
2013-05-11 16:25:35.990 アプリ [18843:c07] CoreData: エラー: 重大なアプリケーション エラーです。コア データの変更処理中に例外がキャッチされました。これは通常、NSManagedObjectContextObjectsDidChangeNotification のオブザーバー内のバグです。ALL または ANY 演算子の左側は、NSArray または NSSet でなければなりません。userInfo (ヌル)
2013-05-11 16:25:35.992 アプリ [18843:c07] *キャッチされない例外 'NSInvalidArgumentException' が原因でアプリを終了しています。
*最初のスロー コール スタック:
通知オブザーバーの提案を手がかりに、おそらくスコープ内の NSManagedObjectContext の唯一のオブザーバーである NSFetchedResultsController を調べました。
-(NSFetchedResultsController *)typesController
{
if (_typesController) {
return _typesController;
}
// Set up the fetched results controller.
// Create the fetch request for the entity.
NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
// Edit the entity name as appropriate.
NSEntityDescription *entity = [NSEntityDescription entityForName:@"IssueType" inManagedObjectContext:self.managedObjectContext];
[fetchRequest setEntity:entity];
// Set the batch size to a suitable number.
[fetchRequest setFetchBatchSize:20];
// Filter out the required types
NSPredicate *exclude = [NSPredicate predicateWithFormat:@"NONE name in %@",excludedTypes];
[fetchRequest setPredicate:exclude];
// Edit the sort key as appropriate.
NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"name" ascending:YES];
NSArray *sortDescriptors = [NSArray arrayWithObjects:sortDescriptor, nil];
[fetchRequest setSortDescriptors:sortDescriptors];
// Edit the section name key path and cache name if appropriate.
// nil for section name key path means "no sections".
NSFetchedResultsController *aFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:self.managedObjectContext sectionNameKeyPath:nil cacheName:nil];
aFetchedResultsController.delegate = self;
self.typesController = aFetchedResultsController;
NSError *error = nil;
if (![_typesController performFetch:&error]) {
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
[self failAlertWithMessage:nil forceAbort:YES];
}
return _typesController;
}
述語を作成して割り当てる行をコメントアウトすると、クラッシュしないことがわかりました。もちろん、隠したいオブジェクトをいくつか表示しています。述語自体に問題は見られません。フェッチは予想されるオブジェクトを返し、excludedTypes Array 内のオブジェクトを意図したとおりに除外します。
コンテキストを保存する方法では、既存のオブジェクトの編集または削除に関する問題は発生せず、新しいオブジェクトの挿入時にのみ問題が発生します。
ここでは、メイン スレッド以外のスレッドを使用していません。