0

UPDATED バージョンのコア データがバックグラウンドで更新されました

Grand Central Dispatch (GCD) と CoreDataのリンクを使用してバックグラウンドの managedObjectContext を作成しましたが、コア データからフェッチするときにエラーが発生します

-(void) startTimerThread
{
    dispatch_async( dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
        // Add code here to do background processing
        NSManagedObjectContext *context = [[NSManagedObjectContext alloc] init];
        self.backgroundManagedObjectContext = context;
        [self.backgroundManagedObjectContext setPersistentStoreCoordinator:self.managedObjectContext.persistentStoreCoordinator];
        self.managedObjectContext = self.backgroundManagedObjectContext;
        [self getDataFromFile];

    dispatch_async( dispatch_get_main_queue(), ^{
        // Add code here to update the UI/send notifications based on the
        // results of the background processing

        [[NSNotificationCenter defaultCenter] postNotificationName:@"ReloadAppDelegateTable" object:nil];
        [context release];
        self.managedObjectContext = [(AppDelegate *)[[UIApplication sharedApplication] delegate] managedObjectContext];
    });
});

}

そして、私getDataFromFileがフェッチしようとするとエラーが発生しますmanagedObjectContext

NSFetchRequest *request = [[NSFetchRequest alloc] init];
[request setPredicate:[NSPredicate predicateWithFormat:@"date == max(date)"]];
NSEntityDescription *entity = [NSEntityDescription entityForName:@"LogDetails" inManagedObjectContext:self.managedObjectContext];

同じエラー:

Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: '+entityForName: could not locate an NSManagedObjectModel for entity name LogDetails

このエラーが発生する理由を誰かに教えてもらえますか。以前は、同じエラーが発生していた子 managedObjectContext を作成しようとしていました。

前もって感謝します。

4

1 に答える 1

1

コンテキストを作成してそれを self.backgroundManagedObjectContext に設定してから、それを self.managedObjectContext に設定する理由がよくわかりません。私が提案するのは、 getDataFromFile メソッドがコンテキストを取り込めるようにして、任意のスレッドから呼び出すことができるようにすることです。

あなたが持っているだろう

- (void)getDataFromFileOnContext:(NSManagedObjectContext *)context
{
    NSFetchRequest *request = [[NSFetchRequest alloc] init];
    [request setPredicate:[NSPredicate predicateWithFormat:@"date == max(date)"]];
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"LogDetails" inManagedObjectContext:context];
}

次に、これを行うことができます

-(void) startTimerThread
{
    self.managedObjectContext = [(AppDelegate *)[[UIApplication sharedApplication] delegate] managedObjectContext];

    dispatch_async( dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
        // Add code here to do background processing
        NSManagedObjectContext *context = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSPrivateQueueConcurrencyType];
        [context setParentContext:self.managedObjectContext];
        [self getDataFromFileOnContext:context];

    dispatch_async( dispatch_get_main_queue(), ^{
        // Add code here to update the UI/send notifications based on the
        // results of the background processing

    [[NSNotificationCenter defaultCenter] postNotificationName:@"ReloadAppDelegateTable" object:nil];        
    });
});

さらにサポートが必要な場合はお知らせください。

于 2013-03-07T18:16:57.270 に答える