gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 10:43:22 25 4
gpt4 key购买 nike

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

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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com