IPhone-核心数据崩溃-多个托管对象上下文

IPhone-核心数据崩溃-多个托管对象上下文,iphone,objective-c,cocoa-touch,core-data,nsmanagedobjectcontext,Iphone,Objective C,Cocoa Touch,Core Data,Nsmanagedobjectcontext,所以,我使用多线程的核心数据。每个人都有自己的托管对象上下文。 我得到一个无法识别的选择器异常,所以我很好奇我是否做错了什么。 崩溃显然与“mergeChanges”方法有关。 我将非常感谢任何帮助 编辑 问题似乎是myManagedObjectContext返回一个解除分配的对象。 怎么可能呢 My code: - (NSManagedObjectContext *) myManagedObjectContext { NSManagedObjectContext * result

所以,我使用多线程的核心数据。每个人都有自己的托管对象上下文。 我得到一个无法识别的选择器异常,所以我很好奇我是否做错了什么。 崩溃显然与“mergeChanges”方法有关。 我将非常感谢任何帮助

编辑 问题似乎是myManagedObjectContext返回一个解除分配的对象。 怎么可能呢

My code:

- (NSManagedObjectContext *) myManagedObjectContext {


    NSManagedObjectContext * result = [[[NSThread currentThread] threadDictionary] objectForKey: AQPerThreadManagedObjectContext];
    if ( result != nil )
        return result;

    NSPersistentStoreCoordinator *coordinator = [self persistentStoreCoordinator];
    if (coordinator!=nil)
    {


    NSManagedObjectContext * moc = [[NSManagedObjectContext alloc] init];
    [moc setMergePolicy: NSMergeByPropertyObjectTrumpMergePolicy];
    [moc setPersistentStoreCoordinator: coordinator];
    [self StoreManagedObjectContextForCurrentThread:moc];
    [moc release];      // now owned by the thread dictionary
    return moc ;
    }
    else {
        GTMLoggerError(@"FAILED TO return managed object context ");

    }


    return nil; 
}

-(void) StoreManagedObjectContextForCurrentThread:(NSManagedObjectContext*) context
{
    [[[NSThread currentThread] threadDictionary] setObject: context forKey: AQPerThreadManagedObjectContext];
}

-(BOOL) saveChanges
{
    BOOL success = YES;
    NSManagedObjectContext* moc = [self myManagedObjectContext];

    NSNotificationCenter *nc = [NSNotificationCenter defaultCenter]; 

    [nc addObserver:self
           selector:@selector(mergeChanges:)
               name:NSManagedObjectContextDidSaveNotification
             object:moc];

        NSError *error = nil;
        if ([moc save:&error] == NO)
        {
                    success = NO;
            GTMLoggerError(@"Failed to save to data store: [%@], [%@]", 
                           [error localizedDescription],
                           [error userInfo]);
        }


 return success;
 } 
- (void)mergeChanges:(NSNotification *)notification
{

    NSManagedObjectContext* moc = [self myManagedObjectContext];

    AppDelegate * delegate = (AppDelegate *)[[UIApplication sharedApplication] delegate];
    NSManagedObjectContext *mainContext = [delegate mainThreadMOC];

    // Merge changes into the main context on the main thread
    [mainContext performSelectorOnMainThread:@selector(mergeChangesFromContextDidSaveNotification:)
                                  withObject:notification
                               waitUntilDone:YES];  

    NSNotificationCenter *nc = [NSNotificationCenter defaultCenter]; 

    [nc removeObserver:self name:NSManagedObjectContextDidSaveNotification object:moc];
} 

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{

    mainThreadMOC = [[NSManagedObjectContext alloc]init];
    [mainThreadMOC setMergePolicy: NSMergeByPropertyObjectTrumpMergePolicy];
    [mainThreadMOC setPersistentStoreCoordinator: [[DatabaseManager sharedManager] persistentStoreCoordinator]];



    [[DatabaseManager sharedManager] StoreManagedObjectContextForCurrentThread:mainThreadMOC];
.....
.....
}
由于未捕获的异常“NSInvalidArgumentException”而终止应用程序,原因:“-[NSKeyPathExpression\u processReferenceQueue:]:无法识别的选择器已发送到实例0xa65940”

0   CoreFoundation                      0x3587a987 __exceptionPreprocess + 114
1   libobjc.A.dylib                     0x34a8249d objc_exception_throw + 24
2   CoreFoundation                      0x3587c133 -[NSObject(NSObject) doesNotRecognizeSelector:] + 102
3   CoreFoundation                      0x35823aa9 ___forwarding___ + 508
4   CoreFoundation                      0x35823860 _CF_forwarding_prep_0 + 48
5   CoreData                            0x356ea3d5 -[NSManagedObjectContext(_NSInternalNotificationHandling) _processReferenceQueue:] + 24
6   CoreData                            0x3573032b -[NSManagedObjectContext mergeChangesFromContextDidSaveNotification:] + 842
7   CoreFoundation                      0x35818bbf -[NSObject(NSObject) performSelector:withObject:] + 22
8   Foundation                          0x31181795 __NSThreadPerformPerform + 268
9   CoreFoundation                      0x358307dd __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 12
10  CoreFoundation                      0x358025b7 __CFRunLoopDoSources0 + 382
11  CoreFoundation                      0x35801e5b __CFRunLoopRun + 230
12  CoreFoundation                      0x35801c87 CFRunLoopRunSpecific + 230
13  CoreFoundation                      0x35801b8f CFRunLoopRunInMode + 58
14  GraphicsServices                    0x320c84ab GSEventRunModal + 114
15  GraphicsServices                    0x320c8557 GSEventRun + 62
16  UIKit                               0x341dc329 -[UIApplication _run] + 412
17  UIKit                               0x341d9e93 UIApplicationMain + 670

不确定这是否是问题所在,但您应该始终从函数返回自动删除的值

你正在做:

[moc release];      // now owned by the thread dictionary
return moc ;
但不管线程字典中的所有权如何,它都应该是:

return [moc autorelease];

不确定这是否是问题所在,但您应该始终从函数返回自动删除的值

你正在做:

[moc release];      // now owned by the thread dictionary
return moc ;
但不管线程字典中的所有权如何,它都应该是:

return [moc autorelease];

嗨,不知道为什么,但目前没有发生崩溃,所以它可能已经解决了我的问题。这有点奇怪,因为不管怎样,我希望moc会一直保留在线程字典中。将等待一段时间,如果没有出现,将标记您的答案为已接受。谢谢dudeHi,不知道为什么,但目前没有发生崩溃,所以它可能已经解决了我的问题。这有点奇怪,因为不管怎样,我希望moc会一直保留在线程字典中。将等待一段时间,如果没有出现,将标记您的答案为已接受。谢谢你,伙计