.dSYM文件
是debugger Symbols 的簡(jiǎn)稱,是一個(gè)符號(hào)表文件,保存 16 進(jìn)制函數(shù)地址映射信息的中轉(zhuǎn)文件审轮,我們調(diào)試的 symbols 都會(huì)包含在這個(gè)文件中,包括文件名贞滨、函數(shù)名旁舰、行號(hào)等.
.crash文件
奔潰文件,當(dāng)我們APP崩潰時(shí)會(huì)生成.crash文件对竣,自動(dòng)保存在設(shè)備本地锣光,App上線以后蘋(píng)果就會(huì)自動(dòng)捕捉崩潰信息,當(dāng)App出現(xiàn)Crash后iOS系統(tǒng)就會(huì)記錄崩潰日志并上傳到Appple的服務(wù)器述寡。前提是需要用戶同意 “與應(yīng)用開(kāi)發(fā)者共享”柿隙。
步驟為 設(shè)置->隱私->診斷與用量->與應(yīng)用開(kāi)發(fā)者共享
關(guān)于崩潰的確切語(yǔ)句和函數(shù)部分只有16進(jìn)制地址符號(hào),所以需要使用.dSYM文件來(lái)對(duì)地址進(jìn)行解析鲫凶,如下圖,都是地址衩辟,沒(méi)發(fā)直接閱讀螟炫。
獲取.dSYM文件分debug和release
release:選擇window->organizer-archives,右擊艺晴,選擇Show in Finder就可以選中archived 文件然后顯示包內(nèi)容昼钻,就可以找到dSYM文件了。
debug:在項(xiàng)目工程里面的 Products 文件的 xxx.app 文件里面可以找到 xxxx.app.dSYM 文件封寞,找不到需要在工程配置一下然评,然后重新運(yùn)行。
獲取crash文件分線上和線下
線上:如果APP已經(jīng)上線了狈究,直接打開(kāi)xcode->window->organizer-Crashes,需要聯(lián)網(wǎng)獲取碗淌,如下圖展示的就是你線上版本的crash日志,左上角可以切換不同的構(gòu)建版本抖锥。
右鍵show in finder亿眠,就可以獲取到對(duì)應(yīng)的.crash文件,這個(gè)文件是已經(jīng)符號(hào)化的磅废,不需要解析纳像,可以直接查看。
線下:APP崩潰后的日志是保存在手機(jī)上的拯勉,需要與電腦上的iTunes同步竟趾,即將崩潰日志保存在電腦上的文件夾中
具體文件位置:
Mac OS X:~/Library/Logs/CrashReporter/MobileDevice
Windows XP:C:\Documents and Settings\Application Data\Apple computer\Logs\CrashReporter
Windows 7/Vista: C:\Users\計(jì)算機(jī)登錄名\AppData\Roaming\Apple Computer\Logs\CrashReporter\MobileDevice
或者直接使用xcode查看,xcode 會(huì)自動(dòng)符號(hào)化
或者使用iTools進(jìn)入“工具箱”tab,點(diǎn)擊崩潰日志宫峦,進(jìn)入崩潰日志頁(yè)面岔帽,導(dǎo)出對(duì)應(yīng)的crash文件。
symbolicatecrash
Xcode自帶的崩潰分析工具斗遏,使用這個(gè)工具可以更精確的定位崩潰所在的位置山卦,將0x開(kāi)頭的地址替換為響應(yīng)的代碼和具體行數(shù)。
? ~ find /Applications/Xcode.app -name 'symbolicatecrash'
/Applications/Xcode.app/Contents/Developer/Platforms/WatchSimulator.platform/Developer/Library/PrivateFrameworks/DVTFoundation.framework/symbolicatecrash
/Applications/Xcode.app/Contents/Developer/Platforms/AppleTVSimulator.platform/Developer/Library/PrivateFrameworks/DVTFoundation.framework/symbolicatecrash
/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/Library/PrivateFrameworks/DVTFoundation.framework/symbolicatecrash
/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash
這里使用最后一個(gè)
/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash
1.在桌面創(chuàng)建一個(gè)crash文件夾诵次,然后將這個(gè)工具copy進(jìn)去账蓉,使用命令如下
cp /Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash ~/Desktop/Crash
2.將獲取到.crash,.dSYM,symbolicatecrash都放到剛剛創(chuàng)建的crash文件夾。執(zhí)行如下命令
./symbolicatecrash ./*.crash ./*.app.dSYM > symbol.crash
如果報(bào)錯(cuò)Error: "DEVELOPER_DIR" is not defined at ./symbolicatecrash line 69.逾一,再執(zhí)行如下命令設(shè)置一下導(dǎo)出的環(huán)境變量
export DEVELOPER_DIR=/Applications/XCode.app/Contents/Developer
然后重新導(dǎo)出铸本。
這個(gè)symbol.crash就是解析好的文件。打開(kāi)如下
變成我們能看的懂得了遵堵。
參考文章:http://www.reibang.com/p/480c0a2ac1a4
http://www.reibang.com/p/0b6f5148dab8
http://www.cocoachina.com/articles/6677
還有個(gè)工具也不錯(cuò)dSYMTools
https://github.com/answer-huang/dSYMTools