工作中难免或碰到crash,如果是开发环境,碰到简单的crash还能重现下,如果不能重现的话,我们只能去分crash文件了。

首先看下面的crash问题,说句实话一看这个我是拒绝的,这怎么找原因啊,头都大了。

68BFD825-BB35-4106-B030-772B9884FB82.png

1、 进程信息
第一部分是闪退进程的相关信息。

Incident Identifier : 是崩溃报告的唯一标识符。

CrashReporter Key: 是与设备标识相对应的唯一键值。虽然它不是真正的设备标识符,但也是一个非常有用的情报:如果你看到100个崩溃日志的CrashReporter Key值都是相同的,或者只有少数几个不同的CrashReport值,说明这不是一个普遍的问题,只发生在一个或少数几个设备上。

Hardware Model :标识设备类型。 如果很多崩溃日志都是来自相同的设备类型,说明应用只在某特定类型的设备上有问题。上面的日志里,崩溃日志产生的设备是iPhone 4s。

接下来几行不言自明,无需赘述。

(2) 基本信息
这部分给出了一些基本信息,包括闪退发生的日期和时间,设备的iOS版本。
(3) 异常
Exception Type:异常的类型。
Exception Codes :异常错误码
Termination Reason:闪退的原因,比如常见的数组越界啊,什么的。
Triggered by Thread:出现问题在哪个线程,这个比较重要,首先确定在哪个线程中出了问题,然后再去定位。

(4) 线程回溯
这部分提供应用中所有线程的回溯日志。 线程调用的一些,堆栈信息,压根看不懂,所有需要进行符号化处理。

用Xcode自带的 symbolicatecrash 工具来解析的.crash文件

1、获取crash文件:
a、直接从设备中获取方法如下图

屏幕快照 2016-09-21 下午9.16.49.png

b、苹果审核那边发给你的(我的就是)

2、找到app包所对应的.dSYM文件,强调要对应
.dSYM 是保存 16 进制函数地址映射信息的中转文件,我们调试的 symbols 都会包含在这个文件中,并且每次编译项目的时候都会生成一个新的 dSYM 文件。测试给过来的.crash文件中,关于崩溃的确切语句和函数部分只有16进制地址符号,并不是我们在xcode调试时看到的xxx.cpp(xxfunction xx行)这样的。一般发布一个版本需要保存好对应的.dSYM和.app包,方便分析crash

屏幕快照 2016-09-21 下午9.21.56.png

3、就是找到Xcode中的symbolicatecrash工具咯,

我用的Xcode8,路径为

/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash

其他版本的xcode,自己百度咯,反正都差不多。把我们需要的工具直接复制到桌面上来(方便用)。

4、.crash文件的分析
a、.配置环境变量DEVELOPER_DIR,(配置好了就不再需要)

export DEVELOPER_DIR=/Applications/Xcode.app/Contents/Developer

b、新建一个文件夹,将第二步中获取的两个文件放在同一个文件夹中

QQ20160921-0.png

QQ20160921-1.png
注意:上面指的是其所在的路径。

经过上面的简单几步我们就能得到格式化好的crash日志,这样就方便我们定位bug的位置了。

源自http://www.jianshu.com/p/e616d094cf65

最新文章

  1. wordpress stratus模板使用 产品显示问题
  2. centos查看系统cpu个数、核心书、线程数
  3. ORACLE--分区表数据清理
  4. ComboGrid( 数据表格下拉框)
  5. 【游戏】2048及各种变种大集合汇总【更新ing~新版Floppy2048 - 恒星聚变版 - 恶搞改数据】
  6. 微信小程序入门(三)
  7. (网页)html中页面传递参数不用cookie不用缓存,js方法搞定
  8. Android开发最强模拟器Genymotion的安装及使用教程。附注释图详解
  9. java结合testng,利用yaml做数据源的数据驱动实例
  10. >maven-compiler-plugin的理解
  11. Exception in thread "main" java.lang.StackOverflowError at java.util.ArrayList$SubList.rangeCheckForAdd(Unknown Source)
  12. centos7 卸载 jdk
  13. springcloud注解@EnableDiscoveryClient与@EnableEurekaC
  14. 20145127《java程序设计》第四周学习总结
  15. ASP.NET5使用FaceBook登录
  16. gsoap简介
  17. 1014-C程序的语法树
  18. CF868F Yet Another Minimization Problem
  19. ZigzagConvert
  20. 载入本地Html文件

热门文章

  1. 21、java中和日期相关的类
  2. mysql利用yum安装指定数据存放路径
  3. oracle-imp导入小错filesize设置
  4. 安装到LG手机出错
  5. MyEcplise安装Freemarker插件(支持.ftl文件)
  6. cxf之GET,POST,PUT,DELETE的区别
  7. HDUOJ---2082
  8. NYOJ----次方求模
  9. Extending and Embedding PHP
  10. Js操作Select大全(取值、设置选中等等)