ios - 跨多个上下文重用 NSFetchRequest 时崩溃

标签 ios core-data nsmanagedobjectmodel

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

TL;DR:不要在多个 NSManagedObjectContext 对象之间重复使用 NSFetchRequests。查看答案。


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

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

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

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

这是崩溃的回溯:

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

最佳答案

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

关于ios - 跨多个上下文重用 NSFetchRequest 时崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23383646/

相关文章:

iphone - 有没有办法在 UIImage 中制作超越图像堆栈的动画?

ios - 是否需要调用NSManagedObjectContext保存: for in-memory stores?

ios - 使用变量创建 NSPredicate

ios - 下载.xcdatamodeld文件并以编程方式创建.momd

cocoa - 在早期开发过程中,当数据丢失是预期且可接受的时,可轻松进行核心数据迁移

ios - 自动添加的 URL 末尾的 AFNetworking 斜杠

ios - SceneKit:Shademodifier 忽略 Xcode 7 中的自定义全局函数

swift - 如何将 NSDate 保存在取自 UITextField 的 CoreData 中

swift - 需要通用的 FetchedResultsController 构建器(Swift)

core-data - 托管对象模型和持久对象存储之间有什么区别?