小白跟我一起來學(xué)iOS.crash崩潰日志代碼位置定位

今天搗鼓了一天的crash日志終于順利的把16進(jìn)制的堆棧信息還原了笤成,特地來寫個簡書檀头。每個iOS肯定都很羨慕Android的崩潰日志,直接定位到錯誤代碼的位置铝穷,讓你快速定位BUG敦迄,iOS一出現(xiàn)bug就會出現(xiàn)一堆的16進(jìn)制地址恋追,讓人類無法閱讀,今天索性研究了一天,來跟大家分享下如何把這些16進(jìn)制還原成對應(yīng)的代碼位置罚屋,像java一樣定位bug苦囱。

首先來普及下幾個小知識:

1.什么是符號表

符號表就是指在Xcode項(xiàng)目編譯后,在編譯生成的二進(jìn)制文件.app的同級目錄下生成的同名的.dSYM文件.dSYM文件其實(shí)是一個目錄脾猛,在子目錄中包含了一個16進(jìn)制的保存函數(shù)地址映射信息的中轉(zhuǎn)文件撕彤,所有Debug的symbols都在這個文件中(包括文件名、函數(shù)名猛拴、行號等)羹铅,所以也稱之為調(diào)試符號信息文件。

2.符號表有什么用

符號表就是用來符號化 crash log(崩潰日志)愉昆。crash log中有一些方法16進(jìn)制的內(nèi)存地址等职员,通過符號表就能找到對應(yīng)的能夠直觀看到的方法名之類。

3.如何得到.dsYM文件

我們在Archive的時候會生成.xcarchive文件跛溉,然后顯示包內(nèi)容就能夠在里面找到.dsYM文件和.app文件焊切。

下圖是線上收集的bug崩潰信息

花紅圈的地方就我的APP報錯的位置信息,在你們的日志里tcrrdios應(yīng)該是你們對應(yīng)的appname,后面緊跟的是2個16進(jìn)制地址芳室。

解析上面這點(diǎn)信息首先獲取APP編譯時的.xcarchive



OK,以上步驟就可以得到你的.xcarchive专肪。什么?你沒有堪侯?編譯后就刪除了嚎尤?那你就只能等下次了,這個文件沒發(fā)布一次版本最好保存起來防止日后出現(xiàn)問題找到問題的代碼伍宦。

找到了你的.xcarchive右擊“顯示包內(nèi)容”---“dSYMs”-----“[你的appname].app.dSYM”---右擊"顯示包內(nèi)容"---"Contents"-----"Resources"----"DWARF"芽死。這時你會看到和你APPNAME一樣的文件,打開命令行輸入atos -o [拖動地址到這里] -l [16進(jìn)制地址] -arch arm64 [16進(jìn)制地址]雹拄。

以我的文件為例最終命令為:

atos -o /Users/lr_ios1/Desktop/a/tcrrdios.app.dSYM/Contents/Resources/DWARF/tcrrdios-l 0x0000000100030000 -arch arm64 0x00000001000507f4

注意空格J毡肌U莆亍滓玖!注意空格!V式丁势篡!注意空格t婕 !禁悠!重要的事情要說三遍

arm64是根據(jù)你實(shí)際CPU類型念祭,這個現(xiàn)在基本都是64位的了,5以下的機(jī)型就是armv7碍侦。

執(zhí)行完上面的命令得到的結(jié)果是:

-[MainViewController viewDidLoad] (in tcrrdios) (MainViewController.m:31)

這個返回值的意思大家應(yīng)該都能看得懂了粱坤,發(fā)生崩潰的位置就是MainViewController.m這個文件的31行,也就是MainViewController這個類的viewDidLoad函數(shù)中瓷产。

來張圖吧站玄。。濒旦。株旷。


到這里我相信小白也能看得懂了。其實(shí)我也是小白o(hù)(>﹏<)o尔邓。晾剖。。

什么梯嗽?還是太難齿尽?好吧,介紹你們一種圖形界面的方法灯节,炒雞簡單雕什,我就不詳細(xì)介紹了,

https://github.com/answer-huang/dSYMTools

對就是上面的地址显晶,作者已經(jīng)把源碼開源了贷岸,圖形化定位代碼位置夠簡單了吧,上面有操作方法磷雇。

順便提供下下載地址:

https://pan.baidu.com/s/1mg01Qha

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末偿警,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子唯笙,更是在濱河造成了極大的恐慌螟蒸,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,843評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件崩掘,死亡現(xiàn)場離奇詭異七嫌,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)苞慢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評論 3 392
  • 文/潘曉璐 我一進(jìn)店門诵原,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事绍赛÷溃” “怎么了?”我有些...
    開封第一講書人閱讀 163,187評論 0 353
  • 文/不壞的土叔 我叫張陵吗蚌,是天一觀的道長腿倚。 經(jīng)常有香客問我,道長蚯妇,這世上最難降的妖魔是什么敷燎? 我笑而不...
    開封第一講書人閱讀 58,264評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮箩言,結(jié)果婚禮上懈叹,老公的妹妹穿的比我還像新娘。我一直安慰自己分扎,他們只是感情好澄成,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,289評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著畏吓,像睡著了一般墨状。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上菲饼,一...
    開封第一講書人閱讀 51,231評論 1 299
  • 那天肾砂,我揣著相機(jī)與錄音,去河邊找鬼宏悦。 笑死镐确,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的饼煞。 我是一名探鬼主播源葫,決...
    沈念sama閱讀 40,116評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼砖瞧!你這毒婦竟也來了息堂?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,945評論 0 275
  • 序言:老撾萬榮一對情侶失蹤块促,失蹤者是張志新(化名)和其女友劉穎荣堰,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體竭翠,經(jīng)...
    沈念sama閱讀 45,367評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡振坚,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,581評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了斋扰。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片渡八。...
    茶點(diǎn)故事閱讀 39,754評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡啃洋,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出呀狼,到底是詐尸還是另有隱情,我是刑警寧澤损离,帶...
    沈念sama閱讀 35,458評論 5 344
  • 正文 年R本政府宣布哥艇,位于F島的核電站,受9級特大地震影響僻澎,放射性物質(zhì)發(fā)生泄漏貌踏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,068評論 3 327
  • 文/蒙蒙 一窟勃、第九天 我趴在偏房一處隱蔽的房頂上張望祖乳。 院中可真熱鬧,春花似錦秉氧、人聲如沸眷昆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽亚斋。三九已至,卻和暖如春攘滩,著一層夾襖步出監(jiān)牢的瞬間帅刊,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評論 1 269
  • 我被黑心中介騙來泰國打工漂问, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留赖瞒,地道東北人。 一個月前我還...
    沈念sama閱讀 47,797評論 2 369
  • 正文 我出身青樓蚤假,卻偏偏與公主長得像栏饮,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子磷仰,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,654評論 2 354

推薦閱讀更多精彩內(nèi)容