Xcode 4.2 debug不符号堆栈调用我在iOS 5模拟器/设备中调试Xcode 4.2时遇到问题。正如预期的那样,以下代码崩溃:NSArray *arr=[NSArray array];[arr objectAtIndex:100];在iOS 4中,我获得了十六进制数的有用堆栈跟踪。但是在iOS 5中,它只是给了我:*** First throw call stack:(0x16b4052 0x1845d0a 0x16a0674 0x294c 0x6f89d6 0x6f98a6 0x708743 0x7091f8 0x7fcaa9 0x2257fa9 0x16881c5 0x15ed022 0x15eb90a 0x15eadb4 0x15eaccb 0x6f02a7 0x6faa93 0x2889 0x2805)谢谢。
2 回答
梵蒂冈之花
TA贡献1900条经验 获得超5个赞
我没有尝试过会解决这个问题(尝试了两个编译器,两个调试器等)。升级XCode以进行iOS 5更新后,没有任何堆栈跟踪似乎有效。
但是,我找到了一个有效的解决方法 - 创建我自己的异常处理程序(由于其他原因也很有用)。首先,创建一个处理错误并将其输出到控制台的函数(以及您想要用它做的任何其他事情):
void uncaughtExceptionHandler(NSException *exception) { NSLog(@"CRASH: %@", exception); NSLog(@"Stack Trace: %@", [exception callStackSymbols]); // Internal error reporting}
接下来,将异常处理程序添加到您的应用程序委托:
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions{ NSSetUncaughtExceptionHandler(&uncaughtExceptionHandler); // Normal launch stuff}
而已!
如果这不起作用,那么只有两个可能的原因:
有些东西会覆盖你的
NSSetUncaughtExceptionHandler
电话(你的整个应用只能有一个处理程序)。例如,某些第三方库设置了自己的uncaughtExceptionHandler。因此,尝试在didFinishLaunchingWithOptions
功能的END处设置它(或选择性地禁用第三方库)。或者更好的是,设置一个符号断点NSSetUncaughtExceptionHandler
,快速查看谁在调用它。您可能想要做的是修改当前的而不是添加另一个。你没有真正遇到异常
- 2 回答
- 0 关注
- 568 浏览
添加回答
举报
0/150
提交
取消