关于Xcode不能打印崩溃日志

本文始建于本人博客园:图灵2014  2015-10-21 17:44

链接:关于Xcode不能打印崩溃日志


最近在调试应用的时候发现了一个问题, 就是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];

这里不得不得吐槽一下官方的教程, 换了类名但是教程还是没有及时更改, 害我找这个方法找了10分钟.

[AVOSCloudCrashReporting enable];

总结

一般Xcode不输出Crash日志有一下几个可能:

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

2. 还一种崩溃的情况是 EXC_BAD_ACCESS 当遇到这种错误, 控制一般不会给你很多关于崩溃的信息, 这种崩溃你只能使用下面这个调试方法, 不过记住你在正式发布的时候记得把这个勾取消, 不然会造成一些严重的问题(所有对象都不会被release,内存会一直涨).


转自:南望青天的文章


补充:我的项目之所以无法打印错误日志是因为使用了bugly崩溃日志管理SDK. bugly中有一个方法:

日志输出控制

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

- (void)enableLog:(BOOL)enabled;

当此项设置为 NO时,工程中很多crash将没有提示信息,默认关闭

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 最近在调试应用的时候发现了一个问题, 就是Xcode的控制台不打印Crash日志. 几经周折终于发现了问题. 因为...
    南国青天阅读 14,956评论 5 20
  • LLVM简介 XCode4.0以后,LLVM是构架编译器(compiler)的框架系统,以C++编写而成,用于优化...
    苦工阅读 9,885评论 1 16
  • 前言 崩溃是让发人员比较头痛的事情,app崩溃了,说明代码写的有问题,这时如何快速定位到崩溃的地方很重要。调试阶段...
    進无尽阅读 2,109评论 0 9
  • 转载(漫谈 iOS Crash 收集框架) 前言 很早以前就和念茜认识,念茜不但技术功底扎实,而且长得很漂亮,说她...
    狂风无迹阅读 3,522评论 1 11
  • 前言 接触《简书》也有快一年的时间了,其简约的界面、丰富的主题文章、每天大量干货的文章更新都深深触动着我,每天的琐...
    dean550阅读 554评论 0 1