我有一个非常奇怪的问题。
最近我为我的iOS项目(arm64)添加了64位支持,自从我开始接收@try...@catch
内部代码段的未捕获异常(我使用Crashlytics进行崩溃报告)。我设法在我的应用程序的任何地方使用以下代码行重现问题(我在其中一个视图控制器的init
内写了它们):
@try {
NSMutableDictionary *m = [[NSMutableDictionary alloc] init];
NSString *s;
m[s] = @"poop";
} @catch (NSException *e) {
NSLog(@"POOP");
}
异常被UncaughtExceptionHandler
而不是@catch
子句捕获。我对可能导致这种情况的原因感到困惑。控制台中的输出:
2015-02-22 19:19:53.525 [391:30650] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '*** setObjectForKey: key cannot be nil'
*** First throw call stack:
(0x18823a59c 0x1989400e4 0x1881251f8 0x10011e2f4 0x10011e068 0x10010e480 0x10010db78 0x10010d944 0x1000a8050 0x100075d88 0x100075160 0x100142044 0x100141f6c 0x18c9ecaa0 0x18caa1fb4 0x18caa1eb0 0x18caa134c 0x18caa0ff8 0x18caa0d18 0x18caa0c98 0x18c9e9648 0x18c341994 0x18c33c564 0x18c33c408 0x18c33bc08 0x18c33b98c 0x18cc76dbc 0x18cc77c68 0x18cc75dec 0x1904b162c 0x1881f2a28 0x1881f1b30 0x1881efd30 0x18811d0a4 0x18ca573c8 0x18ca523c0 0x1000747d8 0x198faea08)
libc++abi.dylib: terminating with uncaught exception of type NSException
我尝试删除我拥有的自定义异常处理程序并禁用Crashlytics,但仍然没有成功。
一旦我从arm64
和ARCHS
移除VALID_ARCHS
,代码就会正常运行,异常会按预期捕获。
任何信息都将不胜感激!
小更新 - 我们的XCTests也开始不捕获异常,直到现在这种行为才发生在物理64位手机上。
答案 0 :(得分:4)
经过长时间的git-bisecting之后,罪魁祸首是以下链接器标志
-no_compact_unwind
我使用的BlocksKit v2.2.0仍然有那个标志,即使它停止使用libffi(最新版本的BlocksKit删除了那个不需要的标志)。一旦我删除了链接器标志,64位@try...@catch
块就会再次开始工作。
我仍然没有完全理解为什么会出现这种情况,但如果我发现任何有趣的事情,我会更多地了解并更新这个帖子。
唷
答案 1 :(得分:0)
在iOS和Objective-C上,异常仅用于不可恢复的编程错误,而不用于程序执行控制。
特别是它们不处理API中堆栈帧的捕获。