- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在使用 Core Data 时遇到了一个非常奇怪的问题。让我们来描述一下:
假设我有两个模型,ModelA
和 ModelB
。在数据模型中,ModelA
引用了 ModelB
作为一对多关联,因此 ModelB
具有一对一关联与 ModelA
的关联。
当应用程序启动时(尤其是首次启动时),或者当用户要求时,我必须为每个 ModelA
实例创建或更新所有 ModelB
实例。 ModelA
实例是预先确定的。对于每个 ModelA
实例,我有大约 200 个 ModelB
实例。
我使用这样的代码:
ModelB *model = [NSEntityDescription insertNewObjectForEntityForName:@"ModelB"
inManagedObjectContext:context];
model.value = [NSNumber numberWithDouble:myValue];
model.modelA = modelA; // I pass modelA as a parameter to the function
[modelA addModelBObject:model];
我不会立即保存数据(因为我有很多数据要保存),但我会在流程结束时保存。
有时,也只是有时,我会在这一行收到 EXC_BAD_ACCESS
错误:
model.value = [NSNumber numberWithDouble:myValue];
启用僵尸,除了那个愚蠢的EXC_BAD_ACCESS
,我什么也看不到,没有更多信息。
我尝试以不同的方式设置该值,但没有任何改变。然后,我尝试保留
NSNumber
,但没有任何改变。然后,最后,我尝试保留
创建后的模型,我得到了通常的EXC_BAD_ACCESS
,但对应于模型的创建,也就是说这里:
ModelB *model = [[NSEntityDescription insertNewObjectForEntityForName:@"ModelB"
inManagedObjectContext:context] retain];
您对如何解决这个问题有什么想法吗?难道我做错了什么?顺便说一句,如果我放慢速度(例如,每次创建新模型时都保存上下文),这个问题显然不会发生,但这确实减慢了整个应用程序...
在极少数情况下,我得到了这个堆栈跟踪:
Serious application error. Exception was caught during Core Data change processing. This is usually a bug within an observer of NSManagedObjectContextObjectsDidChangeNotification. -[__NSCFSet addObject:]: attempt to insert nil with userInfo (null)
2011-06-15 11:36:59.864 myApp[457:607] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[__NSCFSet addObject:]: attempt to insert nil'
*** Call stack at first throw:
(
0 CoreFoundation 0x313dc64f __exceptionPreprocess + 114
1 libobjc.A.dylib 0x34b3dc5d objc_exception_throw + 24
2 CoreFoundation 0x313dc491 +[NSException raise:format:arguments:] + 68
3 CoreFoundation 0x313dc4cb +[NSException raise:format:] + 34
4 CoreFoundation 0x31351089 -[__NSCFSet addObject:] + 152
5 CoreData 0x35136dd9 -[NSManagedObjectContext(_NSInternalChangeProcessing) _processPendingUpdates:] + 524
6 CoreData 0x350f4b3d -[NSManagedObjectContext(_NSInternalChangeProcessing) _processRecentChanges:] + 724
7 CoreData 0x351363a5 -[NSManagedObjectContext processPendingChanges] + 16
8 CoreData 0x350d027f _performRunLoopAction + 126
9 CoreFoundation 0x313b3a35 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 16
10 CoreFoundation 0x313b5465 __CFRunLoopDoObservers + 412
11 CoreFoundation 0x313b675b __CFRunLoopRun + 854
12 CoreFoundation 0x31346ec3 CFRunLoopRunSpecific + 230
13 CoreFoundation 0x31346dcb CFRunLoopRunInMode + 58
14 GraphicsServices 0x3658841f GSEventRunModal + 114
15 GraphicsServices 0x365884cb GSEventRun + 62
16 UIKit 0x368ded69 -[UIApplication _run] + 404
17 UIKit 0x368dc807 UIApplicationMain + 670
18 myApp 0x000028cf main + 82
19 myApp 0x00002878 start + 40
)
terminate called after throwing an instance of 'NSException'
这是异常的堆栈跟踪:
#0 0x313f1460 in __CFBasicHashAddValue ()
#1 0x3133fff8 in CFBasicHashAddValue ()
#2 0x31344162 in CFSetAddValue ()
#3 0x31351012 in -[__NSCFSet addObject:] ()
#4 0x3514211a in _PFFastMOCObjectWillChange ()
#5 0x3512ed46 in _PF_ManagedObject_WillChangeValueForKeyIndex ()
#6 0x35132e7e in _sharedIMPL_setvfk_core ()
#7 0x3513316a in _svfk_2 ()
#8 0x0003b750 in -[_TassoStorico setValoreValue:] (self=0x6d97bf0, _cmd=0x49064, value_=1.02600002) at _TassoStorico.m:87
#9 0x0001b62e in -[EuriborParser(hidden) readStoricoForzato] (self=0x74200d0, _cmd=0x48ff7) at EuriborParser.m:236
#10 0x31349f02 in -[NSObject(NSObject) performSelector:withObject:] ()
#11 0x000441c4 in -[MBProgressHUD launchExecution] (self=0x90a6ff0, _cmd=0x4b83f) at MBProgressHUD.m:482
#12 0x352b3388 in -[NSThread main] ()
#13 0x353255cc in __NSThread__main__ ()
#14 0x34e20310 in _pthread_start ()
#15 0x34e21bbc in thread_start ()
最佳答案
CoreData 不是线程安全的;看起来这是你的问题,请尝试查看此 SO question
关于objective-c - 核心数据 : solve a strange EXC_BAD_ACCESS error,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6355126/
reqwest v0.9 将 serde v1.0 作为依赖项,因此实现 converting serde_json errors into reqwest error . 在我的代码中,我使用 se
我有这个代码: let file = FileStorage { // ... }; file.write("Test", bytes.as_ref()) .map_err(|e| Mu
我只是尝试用angular-cli创建一个新项目,然后运行服务器,但是它停止并显示一条有趣的消息:Error: No errors。 我以这种方式更新了(希望有帮助):npm uninstall -g
我从我的 javascript 发送交易 Metamask 打开传输对话框 我确定 i get an error message in metamask (inpage.js:1 MetaMask -
这个问题在这里已经有了答案: How do you define custom `Error` types in Rust? (3 个答案) How to get a reference to a
我想知道两者之间有什么大的区别 if let error = error{} vs if error != nil?或者只是人们的不同之处,比如他们如何用代码表达自己? 例如,如果我使用这段代码: u
当我尝试发送超过 50KB 的图像时,我在 Blazor 服务器应用程序上收到以下错误消息 Error: Connection disconnected with error 'Error: Serv
我有一个error-page指令,它将所有异常重定向到错误显示页面 我的web.xml: [...] java.lang.Exception /vi
我有这样的对象: address: { "phone" : 888, "value" : 12 } 在 WHERE 中我需要通过 address.value 查找对象,但是在 SQL 中有函数
每次我尝试编译我的代码时,我都会遇到大量错误。这不是我的代码的问题,因为它在另一台计算机上工作得很好。我尝试重新安装和修复,但这没有帮助。这是整个错误消息: 1>------ Build starte
在我的代码的类部分,如果我写一个错误,则在不应该的情况下,将有几行报告为错误。我将'| error'放在可以从错误中恢复的良好/安全位置,但是我认为它没有使用它。也许它试图在某个地方恢复中间表情? 有
我遇到了 csv 输入文件整体读取故障的问题,我可以通过在 read_csv 函数中添加 "error_bad_lines=False" 来删除这些问题来解决这个问题。 但是我需要报告这些造成问题的文
在 Spring 中,验证后我们在 controller 中得到一个 BindingResult 对象。 很简单,如果我收到验证错误,我想重新显示我的表单,并在每个受影响的字段上方显示错误消息。 因此
我不知道出了什么问题,因为我用 Java 编程了大约一年,从来没有遇到过这个错误。在一分钟前在 Eclipse 中编译和运行工作,现在我得到这个错误: #A fatal error has been
SELECT to_char(messages. TIME, 'YYYY/MM/DD') AS FullDate, to_char(messages. TIME, 'MM/DD
我收到这些错误: AnonymousPath\Anonymized.vb : error BC30037: Character is not valid. AnonymousPath\Anonymiz
我刚刚安装了 gridengine 并在执行 qstat 时出现错误: error: commlib error: got select error (Connection refused) erro
嗨,我正在学习 PHP,我从 CRUD 系统开始,我在 Windows 上安装了 WAMP 服务器,当我运行它时,我收到以下错误消息。 SCREAM: Error suppression ignore
我刚刚开始一个新项目,我正在学习核心数据教程,可以找到:https://www.youtube.com/watch?v=zZJpsszfTHM 我似乎无法弄清楚为什么会抛出此错误。我有一个名为“Exp
当我使用 Jenkins 运行新构建时,出现以下错误: "FilePathY\XXX.cpp : fatal error C1853: 'FilePathZ\XXX.pch' precompiled
我是一名优秀的程序员,十分优秀!