关于Xcode不能打印崩溃日志,捕捉异常
2016-07-01 17:41
435 查看
最近在调试应用的时候发现了一个问题, 就是Xcode的控制台不打印Crash日志. 几经周折终于发现了问题.
因为不能打印日志, 开始以为是我没有设置
结果还是一样控制台还是只打印了这句话的错误信息:
于是继续寻找原因, 最终在每行代码块都注释的方式来排除问题,最终锁定了问题, 因为我引用了AvosCloud的后台SDK, 它默认开启了将崩溃日志上传的功能, 但是他没有打印本地的崩溃日志, 最后一段代码解决了这个问题.
这里不得不得吐槽一下官方的教程, 换了类名但是教程还是没有及时更改, 害我找这个方法找了10分钟.
屏幕快照 2015-08-01 下午9.25.44.png
文/南国青天(简书作者)
原文链接:http://www.jianshu.com/p/5fc22d09b06f
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。
因为不能打印日志, 开始以为是我没有设置
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 当遇到这种错误, 控制一般不会给你很多关于崩溃的信息, 这种崩溃你只能使用下面这个调试方法, 不过记住你在正式发布的时候记得把这个勾取消, 不然会造成一些严重的问题.
屏幕快照 2015-08-01 下午9.25.44.png
文/南国青天(简书作者)
原文链接:http://www.jianshu.com/p/5fc22d09b06f
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。
相关文章推荐
- 对拍程序
- 对拍程序
- 安装 tomcat
- 用DMA直接驱动GPIO,实现GPIO最高输出速率
- 【项目中---WebView】Webview打开本地图片文件选择解决方案
- Highstock+flask+mysql实现多线条动态刷新
- 有用的工具
- listview如何加载动画,实现每个item都有效果
- poj 3264
- 关于json的问题
- poj 3264
- jQuery控制滚动条滚动到指定位置
- Commons Configuration2 - Quick start guide
- Redis中的发布与订阅
- 新闻发布系统(首页)
- SVProgressHUD 到指定位置
- JSP脚本元素
- LVM系统快照
- Android存储访问及目录
- 获取当前工作目录