您的位置:首页 > 移动开发 > IOS开发

iOS崩溃日志的分析

2017-11-15 16:54 281 查看

崩溃日志的产生


iOS中运行App过程中如果发生程序崩溃,会生成一个崩溃日志文件。这个文件会保存的特定系统目录下,扩展名是crash。当手机连接到iTunes时,会将该文件同步到电脑上。

在Mac系统中这些文件会同步到“~/Library/Logs/CrashReporter/MobileDevice”下。

而在Windows系统中会同步到“C:\Users\\AppData\Roaming\Apple computer\Logs\CrashReporter/MobileDevice”(Vista或以上)或“C:\Documents and Settings\\Application Data\Apple computer\Logs\CrashReporter”(XP)。

崩溃日志的上传


iOS中崩溃日志是可以上传的App Store的服务器,并由开发者查看的。用户可以通过系统设置中的“通用-诊断与用量”来设定是否上传崩溃日志。同时开发者也可以通过捕获异常信号自己定制异常上报。

崩溃日志的格式


一般崩溃日志头部有如下字段

其中Exception Type是异常类型,Exception Codes是异常代码。Crashed Thread指示异常的线程编号。上面表示Crash的线程编号是0(主线程的线程编号是0)。

看崩溃日志时一般要分两种情况,一种是内存、CPU的系统错误,如内存访问错误、除零异常等。另外一种是程序通过写代码抛出的异常,即代码中通过throw关键字抛出的异常。程序抛出的异常是可以捕获并处理的,如果没有捕获,就会Crash,并生成崩溃日志。这两种在日志中有一些细微的差别。

一般内存等系统异常Crash线程信息如下:

第一列是编号,表示堆栈中函数调用的嵌套顺序。最上面就是崩溃发生的函数,往下面看就可以看到我们的代码。第二列是堆栈中函数定义的位置,有的是在动态库或Framework中定义的,有的是我们的App定义的,如QQYanChu就是我们的App可执行文件,另外你还可以看到其他的动态库等,一般我们关注自己的QQYanChu的就行了。 如上面的例子就是在-[QYServerInterface connectionDidFinishLoading:] 这个调用中挂的。一般这个信息还会包含代码文件和说对应的行号,如上面红色部分就是说崩溃在QYServerInterface.m的328行。这就可以方便我们快速定位问题。

下面是程序抛出的异常的日志。

可以看出相比系统异常日志中多出了Last Exception Backtrace字段。上面是线程0崩溃的,而线程0只调用的abort。这是我们要看Last Exception Backtrace这里的堆栈,这个堆栈是抛出异常时的线程当时的堆栈情况,这个信息才是有意义的。在我们程序抛出异常后,系统会执行一系列相关逻辑后调用abort异常结束程序。

符号化Crash

1、iphone连接到Mac 

2、


3、




4、
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: