最近在调试应用的时候发现了一个问题, 就是Xcode的控制台不打印Crash日志. 几经周折终于发现了问题.
因为不能打印日志, 开始以为是我没有设置 NSSetUncaughtExceptionHandler 这个崩溃日志方法于是乎在appDelegate.m添加如下代码:
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
}
结果还是一样控制台还是只打印了这句话的错误信息: libc++abi.dylib: terminate_handler unexpectedly threw an exception 还是与事无补.
于是继续寻找原因, 最终在每行代码块都注释的方式来排除问题,最终锁定了问题, 因为我引用了AvosCloud的后台SDK, 它默认开启了将崩溃日志上传的功能, 但是他没有打印本地的崩溃日志, 最后一段代码解决了这个问题.
[AVAnalytics setCrashReportEnabled:NO];
这里不得不得吐槽一下官