关于Xcode不能打印崩溃日志

最近在调试应用的时候发现了一个问题, 就是Xcode的控制台不打印Crash日志. 几经周折终于发现了问题.c++

由于不能打印日志, 开始觉得是我没有设置 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 仍是与事无补.app

因而继续寻找缘由, 最终在每行代码块都注释的方式来排除问题,最终锁定了问题, 由于我引用了AvosCloud的后台SDK, 它默认开启了将崩溃日志上传的功能, 可是他没有打印本地的崩溃日志, 最后一段代码解决了这个问题.ui

[AVAnalytics setCrashReportEnabled:NO];spa

这里不得不得吐槽一下官方的教程, 换了类名可是教程仍是没有及时更改, 害我找这个方法找了10分钟.
[AVOSCloudCrashReporting enable];调试

总结

通常Xcode不输出Crash日志有一下几个可能:
1. NSSetUncaughtExceptionHandler() 可能被重写了, 你调用以前它以后,(好比你引用了一些第三方库, 它的SDK里面可能包含了把Crash的日志上传到服务器, 这样这个日志可能被重写了, 就不打印本地的崩溃信息了) 尽可能把它放在didFinishLaunchingWithOptions 最后面的一行代码块里.日志

2. 还一种崩溃的状况是 EXC_BAD_ACCESS 当遇到这种错误, 控制通常不会给你不少关于崩溃的信息, 这种崩溃你只能使用下面这个调试方法, 不过记住你在正式发布的时候记得把这个勾取消, 否则会形成一些严重的问题(全部对象都不会被release,内存会一直涨).code

转自:南望青天的文章orm

补充:个人项目之因此没法打印错误日志是由于使用了bugly崩溃日志管理SDK. bugly中有一个方法:对象

  • 日志输出控制

    开启/关闭 Bugly日志输出,默认关闭。建议release 时关闭

  - (void)enableLog:(BOOL)enabled;
当此项设置为 NO时,工程中不少crash将没有提示信息,默认关闭.
相关文章
相关标签/搜索