在項目的開發中,咱們一般須要排查和修改測試中和發佈後線上的一些bug,如今有一些第三方的bug分享和查找工具SDK,如騰訊的Bugly和聽雲等,包括蘋果的開發工具xcode也自帶 bug查找工具。那麼這些工具又是如何獲取到程序中的bug日誌的?這裏就要談到DSYM文件了,一個很重要的東西。android
什麼是DSYM文件?——DSYM是符號表文件xcode
那什麼是符號表了?——符號表是內存地址與函數名、文件名、行號的映射表。符號表元素以下所示:<起始地址> <結束地址> <函數> [<文件名:行號>]服務器
相似於android構建release包時的mapping文件,咱們利用mapping文件能夠將混淆後的APP運行時的現成堆棧信息還原成混淆前的堆棧信息(利用retrace 工具)。因此當應用crash時,咱們能夠利用crash時的堆棧信息獲得對應到源代碼的堆棧信息,還能看到出錯的代碼在多少行,因此能快速定位出錯的代碼位置,以便快速解決問題。而iOS應用crash時也有堆棧,release版的應用,crash時的堆棧信息,全是二進制的地址信息。若是利用這些二進制的地址信息來定位問題是不可能的,所以咱們須要將這些二進制的地址信息還原成源代碼中的函數以及行號,這時候就須要符號表了。舉個例子以下圖app
Xcode編譯項目後,咱們會看到一個同名的 dSYM 文件,dSYM 是保存 16 進制函數地址映射信息的中轉文件,咱們調試的 symbols 都會包含在這個文件中,而且每次編譯項目的時候都會生成一個新的 dSYM 文件,位於 /Users/<用戶名>/Library/Developer/Xcode/Archives 目錄下。iOS 設備中會有日誌文件保存咱們每一個應用出錯的函數內存地址,經過 Xcode 的 Organizer 能夠將 iOS 設備中的 DeviceLog 導出成 crash 文件,這個時候咱們就能夠經過出錯的函數地址去查詢 dSYM 文件中程序對應的函數名和文件名。 ide
如何將文件一一對應函數
每個 xx.app 和 xx.app.dSYM 文件都有對應的 UUID,crash 文件也有本身的 UUID,只要這三個文件的 UUID 一致,咱們就能夠經過他們解析出正確的錯誤函數信息了。工具
1.查看 xx.app 文件的 UUID,terminal 中輸入命令 :dwarfdump --uuid xx.app/xx (xx表明你的項目名)開發工具
2.查看 xx.app.dSYM 文件的 UUID ,在 terminal 中輸入命令:dwarfdump --uuid xx.app.dSYM 測試
3.crash 文件內第一行 Incident Identifier 就是該 crash 文件的 UUID。ui
在騰訊bugly和聽雲中都實現了符號表自動上傳功能,能夠直接在管理後臺查看到bug報錯的具體位置。原理也是把DSYM文件上傳到他們本身的服務器。
例如聽雲的實現方式以下:
在Xcode工程對應Target的Build Phases
中新增Run Scrpit Phase
使用Xcode 自帶的Crashes工具也能查找bug位置,這個是能查找release線上版本的,debug的沒法查找。
iOS—lj