简书地址
今天审核AppStore被拒,说是有crash错误,并给了.crash文件。但是真机调试模式下没有崩溃,但是在AdHoc的版本下会崩溃,至今不知道为什么。所以我现在想到的只能通过.crash寻找崩溃咯。��
经过一番折腾,找到了问题(一个粗心造成的问题,还是不知道为何真机调试不会出现这问题)。故现在想整理一个详细的笔记:
崩溃分析方式:命令行解析Crash文件
通过Mac自带的命令行工具解析Crash文件需要具备三个文件
获取崩溃信息方式:
这篇文章先只用第四个方式-审核被拒给我的.crash文件,其他方式以后讨论。
1、Xcode-Window-Organize找到要检查的对应Archives找到App-右击-Show in Finder
2、右击 .xcarchive 文件-显示包内容
3、分别复制dSYMs文件夹下的 **.app.dSYM 文件和 Products->Applications文件夹下的 app文件放入 .crash 文件所在的crash文件夹中(文件夹自己建的)。
当程序崩溃的时候,我们可以获得到崩溃的错误堆栈,但是这个错误堆栈都是0x开头的16进制地址,需要我们使用Xcode自带的symbolicatecrash工具来将.Crash和.dSYM文件进行符号化,就可以得到详细崩溃的信息。
1、打开终端输入以下命令:
find /Applications/Xcode.app -name symbolicatecrash -type f
我找到的是:
/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash
2、用命令将symbolicatecrash拷贝到桌面的crash文件夹里面,与.app和.app.dSYM放一起
cp /Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash /Users/***/Desktop/crash
1、打开终端用命令切换到桌面的crash目录下:
cd /Users/***/Desktop/crash
2、执行命令
./symbolicatecrash /Users/***/Desktop/crash/*.crash /Users/***/Desktop/crash/*.app.dSYM > jieguo.crash
2.1、 如果上面命令不成功,使用命令检查一下环境变量
xcode-select -print-path
返回结果:
/Applications/Xcode.app/Contents/Developer/
如果不是上面的结果,需要使用下面命令设置一下导出的环境变量,然后重复上面解析的操作。
export DEVELOPER_DIR=/Applications/XCode.app/Contents/Developer
3、解析完成后会生成一个新的.Crash文件,这个文件中就是崩溃详细信息。