利用.dSYM和.app文件準確定位Crash位置

首先,確保在release(Ad Hoc或者App Store)一個版本時,保存了對應的xxx.app和xxx.dSYM文件。

其次,驗證xxx.crash、xxx.app和xxx.dSYM三者的uuid是否一致。

驗證方法:

1)查看xxx.app的uuid。

  1. $ dwarfdump --uuid mobileguard.app/mobileguard  

2)查看xxx.dSYM的uuid。

  1. $ 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命令。

  1. $ 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。

  1. export DEVELOPER_DIR="/Applications/Xcode.app/Contents/Developer"  

然後執行命令:

  1. symbolicatecrash m.crash mobileguard.app.dSYM > n.crash  

接下來是最重要的環節:

  1. $ xcrun atos -arch armv7 -o mobileguard.app/mobileguard 0x00037000  

下面這個是我機器上看到的結果:

  1. $ xcrun atos -arch armv7 -o mobileguard.app/mobileguard 0x00037000  
  2. -[MobileLocationViewCtrl viewDidLoad] (in mobileguard) (MobileLocationViewCtrl.m:56) 
發佈了25 篇原創文章 · 獲贊 6 · 訪問量 22萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章