原文转自 : http://blog.csdn.net/onlyou930/article/details/7894874

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

分类: iOS Objective-C 658人阅读 评论(0) 收藏 举报

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

我起初也不知道怎么回事,之前似乎也没碰到过。谷歌了一下,看到了一篇文章(http://stackoverflow.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 里面的第一行):

NSSetUncaughtExceptionHandler(&uncaughtExceptionHandler);

posted on 2012-09-12 15:19  BankFish  阅读(472)  评论(0编辑  收藏  举报