核心数据吞噬未捕获的异常

时间:2013-02-11 17:35:38

标签: ios exception core-data

我遇到了令人不安/令人困惑的错误。核心数据似乎吞噬了自己的例外!当使用(超级有用)CoreDataHelper时,我编写了一个格式错误的提取,导致“未实现的SQL生成谓词”异常。那个部分很简单,什么是真的怪异的是这个异常被捕获到某个地方并被吞没,这意味着我的代码在获取之后跳过了方法的其余部分,并且在没有任何控制台消息的情况下返回到主循环。真气。

最终我能够在@try语句中包装实际的获取请求并@catch异常:

@try{
fetchResults = [managedObjectContext executeFetchRequest:request error:&error];
    NSLog(@"fetch successful");
}
@catch (NSException* exception) {
    NSLog(@"caught exception!\n\n%@\n\n%@\n\n%@",[exception name], [exception reason], [exception userInfo]);
}

这让我弄清楚它是什么,但它仍然会让毫无意义它会被某个地方抓住。我没有在我的代码中使用@ try / @ catch else else来测试它。

我还尝试创建一个空白的Core Data项目并使用CoreDataHelper而不使用@ try / @ catch语句尝试隔离问题,项目中没有任何其他东西,CoreDataHelper正常工作,返回:

CoreDataTest[1044:11603] *** Terminating app due to uncaught exception   'NSInvalidArgumentException', reason: 'Unimplemented SQL generation for predicate ("test" LIKE attribute)'

所以我的项目中有些东西正在捕捉并忽略这个异常,但除非我能在不使用@catch的情况下以某种方式做到这一点,否则不是我。

它可能是什么?!

1 个答案:

答案 0 :(得分:2)

知道了!

我正在使用具有自己的库的外部附件(Linea Pro-4条形码扫描仪/ MSR),即使在最新版本的框架中,这也是正在捕获异常的东西。

我设置了我的空白测试项目,以便在运行相同的获取请求之前连接到附件,并且bam!吞下例外!