[iOS]Xcode4/iOS5调试UncaughtException崩溃First throw call stack不打印方法名的解决方案

时间:2023-02-20 18:03:05

最近连接iOS5.0.1真机调试的的时候,发现UncaughtException导致crash之后*** First throw call stack:后面没有打印可读的调用堆栈,以前崩溃之后会显示详细的调用的方法名等信息,但是现在都是一堆内存地址0x…..0x…..。

我起初也不知道怎么回事,之前似乎也没碰到过。谷歌了一下,看到了一篇文章(http://*.com/questions/7841610/xcode-4-2-debug-doesnt-symbolicate-stack-call)讲貌似是iOS5.0开始做了某些修改,导致不能打印方法名了。但是也有补救措施:

自己定义一个方法:

static void uncaughtExceptionHandler(NSException *exception) {

NSLog(@"CRASH: %@", exception);

NSLog(@"Stack Trace: %@", [exception callStackSymbols]);

// Internal error reporting

}


然后在程序初始化的时候调用(比方说放到- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions 里面的第一行):

</pre></p><p class="p1"><pre name="code" class="objc"><span style="font-size:14px;">    NSSetUncaughtExceptionHandler(&uncaughtExceptionHandler);</span><span style="font-size: 13px;">
</span>