背景
开发好的APP上传到ITunes connect上后,用testflight安装测试时,在登录页闪退。因为在开发证书打的生产包上是正常的,没法定位bug,只好根据崩溃日志定位。
概念了解
dSYM符号集
· 符号集使我们对ipa文件进行打包之后,和.app文件同级的后缀名为.dSYM的文件,这个文件必须使用xcode进行打包才有。符号集中存储着文件名、方法名、行号的信息,是和可执行文件的16进制函数地址对应的,通过分析崩溃的.crash文件可以准确知道具体的崩溃信息。
我们每次Archive一个包之后,都会随之生成一个dSYM文件。每次发布一个版本,我们都需要备份这个文件,以方便以后的调试。进行崩溃信息符号化的时候,必须使用当前应用打包的电脑所生成的dSYM文件,其他电脑生成的文件可能会导致分析不准确的问题。
当程序崩溃的时候,我们可以获得崩溃的错误堆栈,但是这个错误堆栈都是0x开头的16进制地址,需要我们使用xcode自带的symbolicatecrash工具来讲.crash和.dSYM文件进行符号化,就可以得到详细崩溃的信息。
崩溃分析
首先,需要确定发生闪退的APP是不是在我自己的电脑上打包的
- 本机:那就可以直接用xcode的window--->DevicesAndSimulators直接对.crash文件进行符号化(将.crash文件拖入到log里面)
- 非本机:symbolicatecrash命令,dSYM文件(有的说还需要.app文件,经亲测.app文件没有也可以成功)
然而不管哪种情况,我们都需要找到其crash的日志
- 已经上线的App,需要从Organizer中下载crash文件,当然需要App的用户的“隐私”‘‘分析’’‘‘共享iPhone分析’’中的‘‘与应用开发者共享’’打开,你才能下载到
- 正在新版本开发的App,需要从闪退的真机的‘‘隐私’’‘‘分析’’’‘分析数据’’中找到对应的crash日志,这些数据可以通过iTunes同步到Mac和xcode上
- 通过iTunes同步之后在相应的路径下查找crash文件
Mac:
~/Library/Logs/CrashReporter/MobileDevice/
xcode:
Xcode->Window->Devices->View Device Logs
如果同步机制无法同步,直接在手机上进行复制粘贴,制作成crash文件
选中archive中的版本右击,选择show in finder 就可以选中archived文件然后显示包内容,就可以找到dSYM文件了。
命令行解析crash文件
通过Mac自带的命令行工具解析crash文件需要具备三个文件
- symbolicatecrash,xcode自带的崩溃分析工具,可以将0x开头的地址替换为相应的代码和具体行数。
- 我们打包时产生的dSYM文件。
- 崩溃时产生的crash文件(或是.ips后缀的,都一样,可以更改后缀为.crash)
在解析崩溃信息时,首先在桌面上建立一个crash文件夹,然后将 .crash、.dSYM、symbolicatecrash放在这个文件夹中,这样进入这个文件夹,直接一行命令就解决了。
命令行:
1. cd /Users/自己MacPro上的名字/Desktop/崩溃文件夹crash
// 使用命令解析crash文件 ,*指的是具体的文件名
2 ./symbolicatecrash ./*.crash ./*.app.dSYM > symbol.crash
打开symbol.crash即可看到符号化后的crash
如果上面的命令不成功,使用命令检查一下环境变量
xcode-select -print-path
返回结果:
/Applications/Xcode.app/Contents/Developer/
如果不是上面的结果,需要使用下面命令设置一下,然后重复上面解析的操作。(这一步很重要)(注意:我操作时发现 即使上面的命令执行成功 符号化也会错误,所以无论上面的命令是否成功 都最好执行一下下面的该命令)
export DEVELOPER_DIR=/Applications/XCode.app/Contents/Developer
解析完成后会生成一个新的.crash文件(在自己建的crash文件夹里),这个文件中就是崩溃详细信息。
注意,以下情况不会有崩溃信息产生:
- 内存访问错误(不是野指针错误)
- 低内存,当程序内存使用过多会造成系统低内存的问题,系统会将程序内存回收
- 因为某种原因触发看门狗机制
查找symbolicatecrash(终端):
find /Applications/Xcode.app -name symbolicatecrash -type f
来获取路径。
我自己电脑的路径是:/Applications/Xcode.app/Contents/Developer/Platforms/AppleTVSimulator.platform/Developer/Library/PrivateFrameworks/DVTFoundation.framework/symbolicatecrash
用命令行将symbolicatecrash拷贝到桌面的crash文件夹里面,与.app和.app.dSYM放一起(手动找到symbolicatecrash,拷贝出来也行)
cp /Applications/Xcode.app/Contents/Developer/Platforms/AppleTVSimulator.platform/Developer/Library/PrivateFrameworks/DVTFoundation.framework/symbolicatecrash /Users/你的电脑名称/Desktop/crash