Xcode7.3工具解析App崩溃日志(.crash文件)

开发的App或者游戏提交审核后,偶尔会收到测试反馈的消息,说应用崩溃了,bug偶尔出现,难以找到确定的重现方法。
怎么办?可以分析崩溃文件啊,也就是app崩溃后,自动保存在设备本地的.crash文件。
获得崩溃日志的方式,在 获取设备上的调试信息与崩溃日志分析 中有说。

在环境ok的情况下,xcode中是可以自动解析.crash文件的。旧版本的xcode甚至可以导入第三方.crash文件,但是xcode7.3貌似是不能导入.crash文件了。
旧版的打开方式是菜单Window-Organizer,界面下方可以直接导入.crash文件,如图:



新版的界面修改了,而且貌似不能直接导入.crash文件,如图:


这时候,我们还是用Xcode自带的 symbolicatecrash 工具来解析测试发来的.crash文件。
1.配置环境变量DEVELOPER_DIR,如果配置过了就跳过此步骤
临时方法:打开终端Terminal,输入命令
[plain] view plain copy

派生到我的代码片
派生到我的代码片

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

永久方法:编辑~/.bash_profile,在末尾添加

[plain] view plain copy

派生到我的代码片
派生到我的代码片

Add environment variable DEVELOPER_DIR

export DEVELOPER_DIR=/Applications/Xcode.app/Contents/Developer
export PATH=$DEVELOPER_DIR:$PATH

然后保存文件,使用source ~/.bash_profile命令或者完全退出终端来刷新环境变量。
2.找到xcode的解析工具 symbolicatecrash 。查询这个工具的路径,貌似很多博客里面都是旧版的xcode了,所以根据博客里面的内容很难找到工具。
我使用的Xcode 7.3版本的 symbolicatecrash 工具路径为
[plain] view plain copy

派生到我的代码片
派生到我的代码片

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

使用其他版本的小伙伴可以看看下面几个目录,或者自行搜索咯[plain] view plain copy

派生到我的代码片
派生到我的代码片

/Applications/Xcode.app/Contents/SharedFrameworks/DTDeviceKit.framework/Versions/A/Resources

[plain] view plain copy

派生到我的代码片
派生到我的代码片

/Applications/Xcode.app/Contents/SharedFrameworks/DTDeviceKitBase.framework/Versions/A/Resources

[plain] view plain copy

派生到我的代码片
派生到我的代码片

/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DTDeviceKit.framework/Versions/A/Resources

找到之后我就直接复制到桌面上来了


3.安装Xcode的Command Line Tools工具,可以查看这篇日志 Xcode中Command Line Tools安装方法
步骤还是打开终端,输入下面的命令即可开始下载安装
[plain] view plain copy
在CODE上查看代码片
在CODE上查看代码片
派生到我的代码片
派生到我的代码片

xcode-select --install

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


我们需要使用.dSYM文件来对地址进行解析,这样就可以看到是是哪个类里面的哪个函数出了问题。如何获取.dSYM文件,在 获取设备上的调试信息与崩溃日志分析 有讲。
如果是本地真机测试,路径应该是
/Users/name/Library/Developer/Xcode/DerivedData/MyApp-aerllxbslxqnjhgfeoiagutyemyz(一串奇怪的值)/Build/Products
目录下的Debug-iphoneos和Release-iphoneos文件夹中都会包含.app和.dSYM文件
如果是发布模式,可以在Xcode的菜单Window-Organizer框中看到发布过的app版本,选择对应版本可以下载.dSYM文件,如下图

正常情况下这样是可以获取到.dSYM文件的,如果不行,那就没法解析.crash文件了。记得看看你的项目配置:


5.获得了.crash文件 .dSYM文件 symbolicatecrash工具 后,就可以开始解析崩溃日志了。
要解析.crash文件,需要与其版本对应的.dSYM文件,也就是需要对应uuid。
使用如下命令可以查看.dSYM文件的uuid
[plain] view plain copy

派生到我的代码片
派生到我的代码片

dwarfdump --uuid /Users/qufangliu/Mydsym.app.dSYM

效果如图



可以打开.crash文件,查看crash文件需要的dSYM文件的uuid,如下图


6.可以看到,我们已经有了对应的.crash和.dSYM文件了。可以直接开始解析了。
解析用的命令格式为:symbolicatecrash解析工具 .crash文件 .dSYM文件 > 输出到某个文件(自定义即可)。结果如图


7.可以查看结果文件了



可以看到,原先的地址符号被解析出来了,我们能直接看到导致崩溃的函数和文件。这样就方便查bug了。

使用symbolicatecrash工具解析崩溃日志条件:
1.配置环境变量DEVELOPER_DIR。
2.找到Xcode的解析工具symbolicatecrash
3.安装了Xcode的Command Line Tools工具
4.获得.crash文件
5.获得.dSYM文件
6..crash文件和.dSYM文件的uuid要对应起来(据说每次打包都会出现不同的.dSYM)

注意:
项目的Debug模式下,默认是不生成.dSYM文件的。如果没有找到,请检测项目设置Build Setting->Build Option项。

疑问:
本地真机调试打包后。目录
/Users/qufangliu/Library/Developer/Xcode/DerivedData/TinyColoroad-fovkdduxiolajbggnwdfrfgqhoaw/Build/Products
下会生成如下文件夹


上面示例里面,Debug-iphoneos文件夹下的.dSYM文件的uuid和我的.crash文件的uuid是对应的。Release-iphoneos文件夹下的.dSYM文件的uuid和我获得的.crash文件的uuid不同,但是也可以正常解析我的.crash文件。哈哈哈哈哈哈哈哈

**

**
**

版权声明:本文为博主原创文章,未经博主允许不得转载。原文链接:http://blog.csdn.net/u011056605

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,029评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,395评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,570评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,535评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,650评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,850评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,006评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,747评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,207评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,536评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,683评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,342评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,964评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,772评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,004评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,401评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,566评论 2 349

推荐阅读更多精彩内容