1

编辑:该线程的原始标题是“创建第二个托管对象模型时崩溃”,但问题已解决,问题结果如上述标题中所述。

TL;DR:不要NSFetchRequests跨多个NSManagedObjectContext对象重用。见答案。


我们看到了一个似乎与 NSEntityDescription 重用有关的问题。

我们有一个应用程序,每个用户使用 Core Data,并允许用户登录和注销。每个会话都有我们称之为核心数据堆栈的东西,它加载一个托管对象模型、存储协调器和我们使用的上下文层次结构。当用户注销时,我们释放堆栈,模型、协调器和上下文都被释放。但是,当用户再次登录时,我们会崩溃。启用僵尸,我们看到以下内容:

2014-04-30 11:31:50.755 CPiPhoneSSLVPN[65981:907] *** -[NSEntityDescription name]: message sent to deallocated instance 0x19888170

每当我们尝试执行 fetch 时,都会发生这种情况。我玩弄了核心数据堆栈,并使模型成为静态的(它按需加载一次,并且永远不会发布),这可以按预期工作。问题是,我们的应用程序在运行时修改模型实体以符合安全策略(例如,我们将某些属性设置为瞬态,以便它们不会存储到磁盘中)。所以制作模型不是一个可行的解决方案。

这是崩溃的回溯:

* thread #1: tid = 0x3c6736, 0x02793411 CoreFoundation`___forwarding___ + 769, name = 'Main', queue = 'com.apple.main-thread', stop reason = EXC_BREAKPOINT (code=EXC_I386_BPT, subcode=0x0)
  * frame #0: 0x02793411 CoreFoundation`___forwarding___ + 769
    frame #1: 0x027930ee CoreFoundation`__forwarding_prep_0___ + 14
    frame #2: 0x0319e71e CoreData`fetchPlanAllocateInitialize + 206
    frame #3: 0x0319e2e4 CoreData`-[NSSQLCore objectsForFetchRequest:inContext:] + 644
    frame #4: 0x0319ddcf CoreData`-[NSSQLCore executeRequest:withContext:error:] + 383
    frame #5: 0x0319d7f2 CoreData`-[NSPersistentStoreCoordinator executeRequest:withContext:error:] + 4466
    frame #6: 0x0319af56 CoreData`-[NSManagedObjectContext executeFetchRequest:error:] + 566
    frame #7: 0x031efd86 CoreData`-[NSManagedObjectContext(_NestedContextSupport) _parentObjectsForFetchRequest:inContext:error:] + 502
    frame #8: 0x0326da14 CoreData`__82-[NSManagedObjectContext(_NestedContextSupport) executeRequest:withContext:error:]_block_invoke + 676
    frame #9: 0x031efb81 CoreData`internalBlockToNSManagedObjectContextPerform + 17
    frame #10: 0x06c2d4d0 libdispatch.dylib`_dispatch_client_callout + 14
    frame #11: 0x06c1c439 libdispatch.dylib`_dispatch_barrier_sync_f_slow_invoke + 80
    frame #12: 0x06c2d4d0 libdispatch.dylib`_dispatch_client_callout + 14
    frame #13: 0x06c1b726 libdispatch.dylib`_dispatch_main_queue_callback_4CF + 340
    frame #14: 0x0280843e CoreFoundation`__CFRUNLOOP_IS_SERVICING_THE_MAIN_DISPATCH_QUEUE__ + 14
    frame #15: 0x027495cb CoreFoundation`__CFRunLoopRun + 1963
    frame #16: 0x027489d3 CoreFoundation`CFRunLoopRunSpecific + 467
    frame #17: 0x027487eb CoreFoundation`CFRunLoopRunInMode + 123
    frame #18: 0x062335ee GraphicsServices`GSEventRunModal + 192
    frame #19: 0x0623342b GraphicsServices`GSEventRun + 104
    frame #20: 0x048ddf9b UIKit`UIApplicationMain + 1225
    frame #21: 0x0003b0e6 CPiPhoneSSLVPN`main(argc=1, argv=0xbfffed7c) + 86 at main.m:17

有没有人见过这种问题?有小费吗?

我已经为此问题打开了错误报告 16767152。

4

1 回答 1

2

问题是我们使用的是缓存的NSFetchRequest. 似乎获取请求在上下文首次使用时在内部缓存实体,稍后如果重用,它会天真地尝试使用其缓存。这造成了上述错误。

于 2014-04-30T17:36:51.220 回答