iOS-symbolicatecrash符号化Crash文件

Posted MinggeQingchun

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了iOS-symbolicatecrash符号化Crash文件相关的知识,希望对你有一定的参考价值。

在我们的app上线了时候,还是会或多或少的存在一些闪退问题,这时候已经无法去调试获取崩溃信息。有些crash日志会传到后台(前提是接口给你提供,你自己也做了这个功能)但是有些crash日志是在用户的iPhone等设备上才能找到的。

对于开发人员来说,有些crash日志不需要用户提供就可以找到日志文件,这时候就要看闪退的app的包是不是在你本机Mac上进行打包的:

本机: 那就可以直接用Xcode的Organizer中直接对Crash进行符号化

非本机: symbolicatecrash 命令,dSYM文件

接下来就说说如何利用symbolicatecrash 命令来将crash文件符号化

1、获取crash日志

(1)本机打包

Windows---->Organizer,直接看到Archives,然后选择你的app以及对应版本,这里可以清晰看到crash所在地方以及机器数量型号等



(2)非本机打包

以前是在"设置->隐私->诊断与用量->诊断与用量数据"中,现在变成了"设置->隐私->分析->分析数据"中,这些数据可以通过iTunes进行同步到Mac和Xcode上。文件名改为app名字.crash

2、导出dSYMs、ipa包

每次Archive成功,都会有对应的Archive文件生成,文件得路径是/Users/用户名/Library/Developer/Xcode/Archives/目录下。找到对应的文件,打开就会看见对应的Archive文件,右键点击该项目,然后点击显示包内容,就会看到对应的文件夹。dSYMsProducts这两个文件夹里面的内容是我们所需要的。分别打开两个文件夹,找到对应的.dSYM.app文件,把这两个文件跟上一步导出的崩溃日志放在同一个文件夹中。

3、查找symbolicatecrash所在路径

find /Applications/Xcode.app -name symbolicatecrash -type f
/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash

耐心等待一会,我们会看到输出四个路径,分平台但是我们需要取第四个路径如上



以上三步完成后,按照如下命令操作

(1)cd <目录>(ipa,dSYM,crash文件共同所在的一级父路径)


(2)运行

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

(3)运行

/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash ./*.crash ./*.app.dSYM > symbol.crash


警告:

[1]symbolicatecrash命令是通过命令获取,将上述获取的路径拷贝过来运行;

[2]虽然切换到ipa,dSYM,crash文件所在的当前文件夹下,如 /Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash demo.crash demo.app.dSYM > symbol.crash但是博主运行时还是报错找不到文件路径,会生成0KB的文件,如下报错:


因此使用以./*广义符代替的路径./*.crash ./*.app.dSYM > symbol.crash,这样就不会有问题了


解析出来文件如下(app名字所在行就是崩溃行):


以上是关于iOS-symbolicatecrash符号化Crash文件的主要内容,如果未能解决你的问题,请参考以下文章

CR, LF, CR/LF 回车 换行

Lora的关键参数SF,CR,BW

vim 中 <CR> 啥意思?

ASCII中LF与CR区别?

关于换行符CR和LF的区别

去除vim ^M符号