@try/@catch 不捕获异常
@try/@catch doesn't catch exception
将 Xcode 从 6.0 升级到 6.3 后,我发现我的自动化测试开始失败。
2015-04-14 18:56:50.625 xctest[48304:517820] *** Terminating app due to uncaught exception 'foo', reason: 'bar'
*** First throw call stack:
(
0 CoreFoundation 0x0084a746 __exceptionPreprocess + 182
1 libobjc.A.dylib 0x004d3a97 objc_exception_throw + 44
2 CoreFoundation 0x0084a66d +[NSException raise:format:] + 141
3 TestTests 0x03e6dbdc -[TestTest test] + 810
4 CoreFoundation 0x0072b84d __invoking___ + 29
5 CoreFoundation 0x0072b6f8 -[NSInvocation invoke] + 360
6 XCTest 0x20108975 -[XCTestCase invokeTest] + 320
7 XCTest 0x20108baa -[XCTestCase performTest:] + 175
8 XCTest 0x20114122 -[XCTest run] + 314
9 XCTest 0x20107598 -[XCTestSuite performTest:] + 406
10 XCTest 0x20114122 -[XCTest run] + 314
11 XCTest 0x20107598 -[XCTestSuite performTest:] + 406
12 XCTest 0x20114122 -[XCTest run] + 314
13 XCTest 0x20107598 -[XCTestSuite performTest:] + 406
14 XCTest 0x20114122 -[XCTest run] + 314
15 XCTest 0x20103df2 __25-[XCTestDriver _runSuite]_block_invoke + 61
16 XCTest 0x20110c42 -[XCTestObservationCenter _observeTestExecutionForBlock:] + 184
17 XCTest 0x20103d16 -[XCTestDriver _runSuite] + 285
18 XCTest 0x20104961 -[XCTestDriver _checkForTestManager] + 272
19 XCTest 0x20104c79 -[XCTestDriver runTestSuite:completionHandler:] + 376
20 XCTest 0x2011772c +[XCTestProbe runTests:] + 216
21 libobjc.A.dylib 0x004e967e +[NSObject performSelector:withObject:] + 70
22 xctest 0x0000823a xctest + 4666
23 xctest 0x000084b0 xctest + 5296
24 xctest 0x00008591 xctest + 5521
25 xctest 0x00007e3d xctest + 3645
26 libdyld.dylib 0x019d4ac9 start + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
经过进一步调查,现在似乎无法捕获异常。这两个片段都会导致此错误。
XCTAssertThrows([NSException raise:@"foo" format:@"bar"]);
和
@try {
[NSException raise:@"foo" format:@"bar"];
}
@catch (NSException *ex) {
NSLog(@"caught");
}
在 VCS 强制清除同步并重建之后,一切看起来都很好,但随后在几次构建时又开始出现同样的故障。有人有什么想法吗?
根据开发者论坛,这似乎是开发者工具中的错误或疏忽导致与使用旧版本工具构建的二进制文件不兼容。
应该在 Xcode 6.4
中修复
将 Xcode 从 6.0 升级到 6.3 后,我发现我的自动化测试开始失败。
2015-04-14 18:56:50.625 xctest[48304:517820] *** Terminating app due to uncaught exception 'foo', reason: 'bar'
*** First throw call stack:
(
0 CoreFoundation 0x0084a746 __exceptionPreprocess + 182
1 libobjc.A.dylib 0x004d3a97 objc_exception_throw + 44
2 CoreFoundation 0x0084a66d +[NSException raise:format:] + 141
3 TestTests 0x03e6dbdc -[TestTest test] + 810
4 CoreFoundation 0x0072b84d __invoking___ + 29
5 CoreFoundation 0x0072b6f8 -[NSInvocation invoke] + 360
6 XCTest 0x20108975 -[XCTestCase invokeTest] + 320
7 XCTest 0x20108baa -[XCTestCase performTest:] + 175
8 XCTest 0x20114122 -[XCTest run] + 314
9 XCTest 0x20107598 -[XCTestSuite performTest:] + 406
10 XCTest 0x20114122 -[XCTest run] + 314
11 XCTest 0x20107598 -[XCTestSuite performTest:] + 406
12 XCTest 0x20114122 -[XCTest run] + 314
13 XCTest 0x20107598 -[XCTestSuite performTest:] + 406
14 XCTest 0x20114122 -[XCTest run] + 314
15 XCTest 0x20103df2 __25-[XCTestDriver _runSuite]_block_invoke + 61
16 XCTest 0x20110c42 -[XCTestObservationCenter _observeTestExecutionForBlock:] + 184
17 XCTest 0x20103d16 -[XCTestDriver _runSuite] + 285
18 XCTest 0x20104961 -[XCTestDriver _checkForTestManager] + 272
19 XCTest 0x20104c79 -[XCTestDriver runTestSuite:completionHandler:] + 376
20 XCTest 0x2011772c +[XCTestProbe runTests:] + 216
21 libobjc.A.dylib 0x004e967e +[NSObject performSelector:withObject:] + 70
22 xctest 0x0000823a xctest + 4666
23 xctest 0x000084b0 xctest + 5296
24 xctest 0x00008591 xctest + 5521
25 xctest 0x00007e3d xctest + 3645
26 libdyld.dylib 0x019d4ac9 start + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
经过进一步调查,现在似乎无法捕获异常。这两个片段都会导致此错误。
XCTAssertThrows([NSException raise:@"foo" format:@"bar"]);
和
@try {
[NSException raise:@"foo" format:@"bar"];
}
@catch (NSException *ex) {
NSLog(@"caught");
}
在 VCS 强制清除同步并重建之后,一切看起来都很好,但随后在几次构建时又开始出现同样的故障。有人有什么想法吗?
根据开发者论坛,这似乎是开发者工具中的错误或疏忽导致与使用旧版本工具构建的二进制文件不兼容。
应该在 Xcode 6.4
中修复