在多个上下文中重用NSFetchRequest时崩溃

时间:2014-04-30 08:49:08

标签: ios core-data nsmanagedobjectmodel

编辑:此主题的原始标题为“创建第二个托管对象模型时出现崩溃”,但问题已解决,问题结果与上述标题中所述相同。 / p>

TL; DR:不要在多个NSFetchRequests对象中重复使用NSManagedObjectContext。见答案。


我们发现一个似乎与NSEntityDescription重用相关的问题变坏了。

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

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

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

以下是崩溃的回溯:

* 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。

1 个答案:

答案 0 :(得分:2)

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