CoreData ManagedObjectContext递归保存错误 [英] CoreData ManagedObjectContext Recursive Save Error
问题描述
我的某些用户在执行保存时遇到CoreData错误。我无法在线找到有关此错误或如何用符号表示堆栈跟踪的任何信息。
Some users of mine are encountering a CoreData error when performing a save. I haven't been able to find any information online about this error or how to symbolicate the stack trace.
错误消息是试图递归递归调用-save:在中止的情况下,进行堆栈跟踪
,并显示以下完整的错误消息。
The error message is attempt to recursively call -save: on the context aborted, stack trace
, with the full error message below.
有人对如何操作有任何提示或想法吗?找出问题出在哪里?
Doe anyone have any hints or ideas on how to figure out what is going wrong?
Error Domain=NSCocoaErrorDomain Code=132001 "(null)" UserInfo={message=attempt to recursively call -save: on the context aborted, stack trace=(
0 CoreData 0x0000000188cbe70c + 164
1 Primetime 0x0000000100077ea4 Primetime + 130724
2 Primetime 0x00000001000ae988 Primetime + 354696
3 Primetime 0x0000000100081674 Primetime + 169588
4 Primetime 0x00000001000802ac Primetime + 164524
5 CoreData 0x0000000188d8bbd4 + 4568
6 CoreData 0x0000000188d8a9ec + 124
7 CoreFoundation 0x00000001869ac24c + 20
8 CoreFoundation 0x00000001869ab950 + 400
9 CoreFoundation 0x00000001869ab6cc + 60
10 CoreFoundation 0x0000000186a187bc + 1504
11 CoreFoundation 0x00000001868ef32c _CFXNotificationPost + 376
12 Foundation 0x000000018738296c + 68
13 CoreData 0x0000000188cc16e8 + 724
14 CoreData 0x0000000188d43ca4 + 1336
15 CoreData 0x0000000188cbfd04 + 2116
16 CoreData 0x0000000188cbe808 + 416
17 Primetime 0x0000000100077ea4 Primetime + 130724
18 Primetime 0x0000000100089968 Primetime + 203112
19 Primetime 0x00000001001d47c0 Primetime + 1558464
20 libdispatch.dylib 0x0000000186459058 + 24
21 libdispatch.dylib 0x0000000186459018 + 16
22 libdispatch.dylib 0x000000018645dbcc _dispatch_main_queue_callback_4CF + 1000
23 CoreFoundation 0x00000001869bfc48 + 12
24 CoreFoundation 0x00000001869bd834 + 1660
25 CoreFoundation 0x00000001868ed764 CFRunLoopRunSpecific + 292
26 GraphicsServices 0x00000001882f0198 GSEventRunModal + 180
27 UIKit 0x000000018c8668d0 + 664
28 UIKit 0x000000018c86163c UIApplicationMain + 208
29 Primetime 0x00000001000ada1c Primetime + 350748
30 libdyld.dylib 0x00000001864905b8 + 4
推荐答案
我没有Xcode8 / ios10也有同样的问题。问题是由于调用以下方法以保存核心数据上下文。
I had the same problem with the Xcode8/ios10. The problem was due to a call to save core data context inside the following method.
- (void)controllerDidChangeContent:(NSFetchedResultsController *)controller {
[self methodCallingSaveContext];
}
The
methodCallingSaveContext
调用保存核心数据上下文。
为了中断递归调用,我以以下方式重写了该方法:
calls the save core data context. In order to break the recursive call I rewrote the method in the following way:
- (void)controllerDidChangeContent:(NSFetchedResultsController *)controller {
dispatch_async(dispatch_get_main_queue(), ^{
[self methodCallingSaveContext];
});
}
现在,一切再次恢复正常。
Now everything is working again.
这篇关于CoreData ManagedObjectContext递归保存错误的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!