利用.dSYM和.app檔案準確定位Crash位置
阿新 • • 發佈:2019-02-05
首先,確保在release(Ad Hoc或者App Store)一個版本時,儲存了對應的xxx.app和xxx.dSYM檔案。
其次,驗證xxx.crash、xxx.app和xxx.dSYM三者的uuid是否一致。
驗證方法:
1)檢視xxx.app的uuid。
$ dwarfdump --uuid mobileguard.app/mobileguard
2)檢視xxx.dSYM的uuid。
$ dwarfdump --uuid mobileguard.app.dSYM/Contents/Resources/DWARF/mobileguard
3)xxx.crash。
Note:
在這之前,需要找到對應的app和dSYM檔案。這兩個檔案是在後綴為.archive的檔案中,在我的機器(Mac OS 10.9.1,Xcode5.0.2)上,.archive檔案在“/Users/mikelin/Library/Developer/Xcode/Archives/”資料夾下對應的日期資料夾中,也可以從Xcode > Organizer > Archive 下找到對應的Archive包。
確保三者uuid一致以後,用symbolicatecrash工具生成易讀的日誌資訊。
先準備環境:
1)連結symbollicatecrash到/usr/bin/中,就可以直接使用sybollicatecrash命令。
$ ln -s /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DTDeviceKitBase.framework/Versions/A/Resources/symbolicatecrash /usr/bin/symbolicatecrash
2)設定xcode DEVELOPER_DIR。
export DEVELOPER_DIR="/Applications/Xcode.app/Contents/Developer"
然後執行命令:
symbolicatecrash m.crash mobileguard.app.dSYM > n.crash
接下來是最重要的環節:
$ xcrun atos -arch armv7 -o mobileguard.app/mobileguard 0x00037000
下面這個是我機器上看到的結果:
$ xcrun atos -arch armv7 -o mobileguard.app/mobileguard 0x00037000 -[MobileLocationViewCtrl viewDidLoad] (in mobileguard) (MobileLocationViewCtrl.m:56)