LLDB 打印變量指令

簡介

lldb提供了3種指令來打印變量溢谤,分別是po、p荞彼、v、今天我們就來看看這3種指令的實現(xiàn)方式和區(qū)別待笑。

po指令

image.png

po指令可以看成是打印變量的固定指令鸣皂,當我們使用po的時候,像上圖一樣我們得到的是文本形式的對象描述暮蹂。po不僅僅能打印變量签夭,還能像下圖一樣拿到對象的名字并計算名字的大寫版本。

image.png

事實上它可以計算任何表達式椎侠,其實po只是一個expression表達式的別名第租,你可以用command alias指令實現(xiàn)自定義的po指令

image.png

下面我們來看看po的底層是如何工作的

image.png

為了提供完整描述,首先它會根據(jù)你輸入的表達式生成一段代碼我纪,然后會在debug程序里編譯并執(zhí)行這段代碼來計算表達式的結(jié)果慎宾,LLDB拿到結(jié)果之后會生成另一短代碼來格式化結(jié)果輸出字符串

p指令

image.png

p指令和po指令打印出來的格式有點不一樣,但是內(nèi)容是一樣的浅悉。而且返回值被起名為R0趟据,這是LLDB的一個約定,每個表達式的結(jié)果會被賦予一個遞增的名字术健。像R0, R1,并且這個被賦予的名字可以用在稍后的表達式中蚂且。你可以像使用其他變量一樣使用R0

image.png

下面讓我們看看p指令在后臺是如何運行的

image.png

事實上p指令底層的第一部分跟po指令是一樣的校摩,會先計算計算表達式的結(jié)果,一旦拿到結(jié)果LLDB會對結(jié)果執(zhí)行動態(tài)類型解析。至于什么是動態(tài)類型解析冯丙,可以用一個例子說明一下

image.png

在上面的例子中既绩,Trip遵守了Activity協(xié)議怠褐,在swift中源碼中的靜態(tài)類型和運行時的動態(tài)類型可以是不一樣的昌腰,像上面的例子一樣,可以用協(xié)議的類型去聲明cruise對象飞醉。cruise的靜態(tài)類型是Acitivity冲茸,但是運行時類型是Trip,如果我們打印cruise我們得到的也是Trip類型缅帘,因為LLDB會根據(jù)元數(shù)據(jù)展示給定變量的精確類型轴术。這就是動態(tài)類型解析

在p指令下,動態(tài)類型解析只會對表達式的結(jié)果執(zhí)行钦无,當我們想打印cruise的name的時候逗栽,這時cruise的類型是Activity,沒有name屬性铃诬,所以就會出錯祭陷,如果要消除錯誤可以把對象轉(zhuǎn)化為其動態(tài)類型

當對結(jié)果執(zhí)行完動態(tài)類型解析苍凛,LLDB會把解析的結(jié)果傳遞給格式化子系統(tǒng)來打印出可讀的字符串

如果你想之后沒有格式化的時候數(shù)據(jù)是什么樣,可以使用 expression --raw --指令查看

image.png

v指令

image.png

v指令的輸出也是依賴LLDB的格式化子系統(tǒng)兵志,v指令是在xcode10才引入的醇蝴,不像其他兩個指令,v不會編譯和執(zhí)行代碼想罕,所以v的執(zhí)行更快速悠栓。v指令有自己的語法,而且它的語法可以跟你在調(diào)試的程序的語言的語法不一樣按价。它可以用.和下標去獲取變量惭适。

image.png

v指令不能計算表達式,因為計算需要執(zhí)行代碼楼镐,如果要執(zhí)行計算表達式可以使用po或者p

image.png

v根據(jù)程序描述去在內(nèi)存種定位變量的位置癞志,然后從內(nèi)存中讀取變量,然后對結(jié)果執(zhí)行動態(tài)類型解析框产,當用于想訪問子字段凄杯,它就對每一個子字段重復(fù)執(zhí)行動態(tài)類型解析,一旦完成秉宿,就會把結(jié)果移交給格式化子系統(tǒng)戒突。

v可能會執(zhí)行多次動態(tài)類型解析,但是格式化只有一次描睦,只是在最后才格式化

總結(jié)

下面是三種指令的對比

image.png

參考

WWDC 2018.LLDB: Beyond "po"

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末膊存,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子忱叭,更是在濱河造成了極大的恐慌隔崎,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件窑多,死亡現(xiàn)場離奇詭異仍稀,居然都是意外死亡,警方通過查閱死者的電腦和手機埂息,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來遥巴,“玉大人千康,你說我怎么就攤上這事〔” “怎么了拾弃?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長摆霉。 經(jīng)常有香客問我豪椿,道長奔坟,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任搭盾,我火速辦了婚禮咳秉,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘鸯隅。我一直安慰自己澜建,他們只是感情好,可當我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布蝌以。 她就那樣靜靜地躺著炕舵,像睡著了一般。 火紅的嫁衣襯著肌膚如雪跟畅。 梳的紋絲不亂的頭發(fā)上咽筋,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天,我揣著相機與錄音徊件,去河邊找鬼晤硕。 笑死,一個胖子當著我的面吹牛庇忌,可吹牛的內(nèi)容都是我干的舞箍。 我是一名探鬼主播,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼皆疹,長吁一口氣:“原來是場噩夢啊……” “哼疏橄!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起略就,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤捎迫,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后表牢,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體窄绒,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年崔兴,在試婚紗的時候發(fā)現(xiàn)自己被綠了彰导。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡敲茄,死狀恐怖位谋,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情堰燎,我是刑警寧澤掏父,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站秆剪,受9級特大地震影響赊淑,放射性物質(zhì)發(fā)生泄漏爵政。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一陶缺、第九天 我趴在偏房一處隱蔽的房頂上張望钾挟。 院中可真熱鬧,春花似錦组哩、人聲如沸等龙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蛛砰。三九已至,卻和暖如春黍衙,著一層夾襖步出監(jiān)牢的瞬間泥畅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工琅翻, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留位仁,地道東北人。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓方椎,卻偏偏與公主長得像聂抢,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子棠众,可洞房花燭夜當晚...
    茶點故事閱讀 42,828評論 2 345

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

  • 隨著Xcode 5的發(fā)布琳疏,LLDB調(diào)試器已經(jīng)取代了GDB,成為了Xcode工程中默認的調(diào)試器闸拿。它與LLVM編譯器一...
    隨風飄蕩的小逗逼閱讀 1,399評論 0 0
  • [轉(zhuǎn)]淺談LLDB調(diào)試器文章來源于:http://www.cocoachina.com/ios/20150126/...
    loveobjc閱讀 2,484評論 2 6
  • 與調(diào)試器共舞 - LLDB 的華爾茲 nangege 2014/12/19 你是否曾經(jīng)苦惱于理解你的代碼空盼,而去嘗試...
    McDan閱讀 881評論 0 0
  • 你是否曾經(jīng)苦惱于理解你的代碼,而去嘗試打印一個變量的值新荤? NSLog(@"%@", whatIsInsideThi...
    木易林1閱讀 954評論 0 4
  • 你是否曾經(jīng)苦惱于理解你的代碼揽趾,而去嘗試打印一個變量的值? NSLog(@"%@", whatIsInsideThi...
    我是啊梁閱讀 801評論 1 1