iOS 常用調(diào)試方法:斷點(diǎn)調(diào)試

級(jí)別: ★☆☆☆☆
標(biāo)簽:「Xcode斷點(diǎn)調(diào)試」「iOS breakpoint」「iOS全局?jǐn)帱c(diǎn)」
作者: Xs·H
審校: QiShare團(tuán)隊(duì)


在iOS項(xiàng)目開發(fā)過程中酥泞,常用到靜態(tài)分析(Analyze)、斷點(diǎn)(Breakpoint)和控制臺(tái)(Console)進(jìn)行代碼調(diào)試。本篇文章介紹Xcode常用調(diào)試方法之“斷點(diǎn)調(diào)試”架专。

一迷郑、簡(jiǎn)介

Xcode的斷點(diǎn)功能是iOS開發(fā)者的常用功能粗蔚。在代碼編輯區(qū)內(nèi)的左邊欄上點(diǎn)擊一下即可創(chuàng)建一個(gè)斷點(diǎn)玫霎,當(dāng)程序每次運(yùn)行到斷點(diǎn)鸽斟,就會(huì)暫停下來,方便開發(fā)者調(diào)試呢诬。如下圖:

同時(shí)涌哲,開發(fā)者可以使用上圖中用數(shù)字標(biāo)記的工具輔助斷點(diǎn)調(diào)試。各工具的作用如下:

  1. 啟用/禁用斷點(diǎn)(點(diǎn)擊后變灰色馅巷,所有斷點(diǎn)失效膛虫;再點(diǎn)擊變藍(lán)色草姻,所有斷點(diǎn)生效)
  2. 繼續(xù)執(zhí)行程序(點(diǎn)擊后跳過本次斷點(diǎn)钓猬,繼續(xù)執(zhí)行程序)
  3. 執(zhí)行下一步(點(diǎn)擊后執(zhí)行第37行代碼)
  4. 進(jìn)入方法(點(diǎn)擊后進(jìn)入-afunction方法)
  5. 跳出方法(在-afunction方法內(nèi)部點(diǎn)擊后回到第36行代碼)

除了斷點(diǎn)的基礎(chǔ)用法,開發(fā)者還可以使用斷點(diǎn)的進(jìn)階功能:編輯斷點(diǎn)撩独、異常斷點(diǎn)符號(hào)斷點(diǎn)敞曹。

二、編輯斷點(diǎn)

雙擊斷點(diǎn)或者右鍵點(diǎn)擊斷點(diǎn)综膀,選擇Edit Breakpoint即可打開斷點(diǎn)編輯頁面澳迫。頁面中包含Condition、Ignore剧劝、Action和Options四個(gè)部分橄登,接下來逐一介紹。

1. Condition

Condition為條件。開發(fā)者可以在Condition輸入框中設(shè)置觸發(fā)斷點(diǎn)的條件拢锹。比如谣妻,在一個(gè)for循環(huán)中,可以設(shè)置在滿足i==5時(shí)才觸發(fā)斷點(diǎn)卒稳。如下圖蹋半。

2. Ignore

Ignore為忽略次數(shù)。開發(fā)者可以在Igore輸入框中設(shè)置忽略此斷點(diǎn)的次數(shù)充坑。比如减江,設(shè)置Ignore為5,則在第6次執(zhí)行到斷點(diǎn)行時(shí)才會(huì)觸發(fā)斷點(diǎn)捻爷。

3. Action

Action為觸發(fā)動(dòng)作辈灼。Action可以添加多條,在觸發(fā)斷點(diǎn)后也榄,會(huì)緊接著執(zhí)行設(shè)定的Actions茵休。Action有6種執(zhí)行類型,其中較常用的有Debugger CommandLog message手蝎,如下圖榕莺。

1) Debugger Command

Debugger Command允許開發(fā)者設(shè)定一些LLDB命令,從而實(shí)現(xiàn)打印對(duì)象棵介、修改變量等功能钉鸯。如下圖。

2) Log Message

Log Message為提供了標(biāo)準(zhǔn)的文本輸出格式邮辽。開發(fā)者可以按照格式設(shè)定在觸發(fā)斷點(diǎn)后輸出的內(nèi)容唠雕。其中,@exp@表示輸出exp的內(nèi)容吨述,%B表示輸出斷點(diǎn)的名稱岩睁,%H表示輸出斷點(diǎn)執(zhí)行的次數(shù)。如下圖揣云。

4. Options

Options控制在執(zhí)行斷點(diǎn)對(duì)應(yīng)的Actions后是否自動(dòng)繼續(xù)執(zhí)行程序捕儒。勾選后Options后,斷點(diǎn)被觸發(fā)后不進(jìn)入Debug界面邓夕。

三刘莹、異常斷點(diǎn)(全局?jǐn)帱c(diǎn))

開發(fā)者可以在Xcode中很方便地創(chuàng)建一個(gè)異常斷點(diǎn)。如下圖:

當(dāng)創(chuàng)建異常斷點(diǎn)后焚刚,會(huì)顯示一個(gè)名為All Exceptions的斷點(diǎn)点弯,所以也常稱作全局?jǐn)帱c(diǎn)。當(dāng)程序拋出異常時(shí)會(huì)觸發(fā)異常斷點(diǎn)矿咕,并且大部分常見錯(cuò)誤會(huì)被斷點(diǎn)定位到對(duì)應(yīng)的代碼行抢肛,很方便調(diào)試狼钮。比如:設(shè)置全局?jǐn)帱c(diǎn)后,我們寫一段數(shù)組越界的代碼捡絮,當(dāng)運(yùn)行到此代碼時(shí)燃领,就會(huì)斷點(diǎn)到越界的那一行。如下圖:

而當(dāng)去掉全局?jǐn)帱c(diǎn)后再次運(yùn)行程序觸發(fā)越界代碼后會(huì)崩潰斷點(diǎn)到main.m中锦援,而不會(huì)定位到越界那一行猛蔽。如下圖:

四、符號(hào)斷點(diǎn)

符號(hào)斷點(diǎn)(Symbolic Breakpoint)是全局?jǐn)帱c(diǎn)灵寺,可以針對(duì)某一個(gè)方法(函數(shù))設(shè)置斷點(diǎn)曼库。開發(fā)者可以很方便地創(chuàng)建一個(gè)符號(hào)斷點(diǎn),如下圖:

與普通斷點(diǎn)相比略板,符號(hào)斷點(diǎn)的編輯界面多出來SymbolModule兩個(gè)輸入框毁枯。

1. Symbol

開發(fā)者可以在Symbol輸入框中設(shè)置斷點(diǎn)出發(fā)方法/函數(shù)。如下圖叮称,在Symbol中設(shè)置一個(gè)方法/函數(shù)后种玛,運(yùn)行程序并執(zhí)行到此方法時(shí)會(huì)觸發(fā)斷點(diǎn)。

這里要注意Symbol中方法/函數(shù)的寫法:
方法(OC方法):用+指明是類方法瓤檐,用-指明是實(shí)例方法赂韵,參數(shù)聲明不可省略,:后不能有空格挠蛉;
函數(shù):(C函數(shù)):直接寫函數(shù)名即可祭示。

2. Module

開發(fā)者可以在Module輸入框中設(shè)置Symbol中的函數(shù)所在的庫,以避免不同庫中存在名字相同的方法/函數(shù)谴古,默認(rèn)不用填寫质涛。

3. Condition等功能

符號(hào)斷點(diǎn)編輯頁面除SymbolModule外的Condition等功能用法與普通斷點(diǎn)一致。比如掰担,在Condition輸入框中設(shè)置$arg3==nil && $arg4==nil汇陆,就會(huì)限制斷點(diǎn)在滿足第一個(gè)參數(shù)和第二個(gè)參數(shù)都為nil時(shí)才會(huì)被觸發(fā)。如下圖:

總結(jié)

Xcode的斷點(diǎn)調(diào)試功能非常強(qiáng)大带饱,開發(fā)者充分利用斷點(diǎn)調(diào)試毡代,再結(jié)合上豐富的LLDB調(diào)試命令,會(huì)在很多程度上提高開發(fā)效率纠炮。


推薦文章:
iOS消息轉(zhuǎn)發(fā)
iOS 自定義拖拽式控件:QiDragView
iOS 自定義卡片式控件:QiCardView
iOS Wireshark抓包
iOS Charles抓包

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末月趟,一起剝皮案震驚了整個(gè)濱河市灯蝴,隨后出現(xiàn)的幾起案子恢口,更是在濱河造成了極大的恐慌,老刑警劉巖穷躁,帶你破解...
    沈念sama閱讀 222,464評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件耕肩,死亡現(xiàn)場(chǎng)離奇詭異因妇,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)猿诸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,033評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門婚被,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人梳虽,你說我怎么就攤上這事址芯。” “怎么了窜觉?”我有些...
    開封第一講書人閱讀 169,078評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵谷炸,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我禀挫,道長(zhǎng)旬陡,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,979評(píng)論 1 299
  • 正文 為了忘掉前任语婴,我火速辦了婚禮描孟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘砰左。我一直安慰自己匿醒,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,001評(píng)論 6 398
  • 文/花漫 我一把揭開白布缠导。 她就那樣靜靜地躺著青抛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪酬核。 梳的紋絲不亂的頭發(fā)上蜜另,一...
    開封第一講書人閱讀 52,584評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音嫡意,去河邊找鬼举瑰。 笑死,一個(gè)胖子當(dāng)著我的面吹牛蔬螟,可吹牛的內(nèi)容都是我干的此迅。 我是一名探鬼主播,決...
    沈念sama閱讀 41,085評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼旧巾,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼耸序!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起鲁猩,我...
    開封第一講書人閱讀 40,023評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤坎怪,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后廓握,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體搅窿,經(jīng)...
    沈念sama閱讀 46,555評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡嘁酿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,626評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了男应。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片闹司。...
    茶點(diǎn)故事閱讀 40,769評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖沐飘,靈堂內(nèi)的尸體忽然破棺而出游桩,到底是詐尸還是另有隱情,我是刑警寧澤耐朴,帶...
    沈念sama閱讀 36,439評(píng)論 5 351
  • 正文 年R本政府宣布众弓,位于F島的核電站,受9級(jí)特大地震影響隔箍,放射性物質(zhì)發(fā)生泄漏谓娃。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,115評(píng)論 3 335
  • 文/蒙蒙 一蜒滩、第九天 我趴在偏房一處隱蔽的房頂上張望滨达。 院中可真熱鬧,春花似錦俯艰、人聲如沸捡遍。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,601評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽画株。三九已至,卻和暖如春啦辐,著一層夾襖步出監(jiān)牢的瞬間谓传,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,702評(píng)論 1 274
  • 我被黑心中介騙來泰國(guó)打工芹关, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留续挟,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,191評(píng)論 3 378
  • 正文 我出身青樓侥衬,卻偏偏與公主長(zhǎng)得像诗祸,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子轴总,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,781評(píng)論 2 361

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

  • XCode 擁有強(qiáng)大的斷點(diǎn)(Breakpoint)調(diào)試功能直颅。 普通斷點(diǎn) 在代碼行旁邊點(diǎn)擊,就能添加一個(gè)斷點(diǎn)怀樟,再次點(diǎn)...
    Stago閱讀 2,810評(píng)論 0 5
  • *****************************(轉(zhuǎn)載自此網(wǎng)址)********************...
    葉舞清風(fēng)閱讀 1,211評(píng)論 0 5
  • 無論你是在技術(shù)棧中使用 Swift功偿,Objective-C,C++漂佩,C脖含,還是完全不同的語言罪塔,都需要學(xué)習(xí)如何創(chuàng)建斷點(diǎn)...
    KarenLoo閱讀 1,454評(píng)論 0 3
  • 一 港島 我的帆船 擱淺在黃金的彼岸 所貪戀的是 港灣里桅桿間吹來的 溫馨夏風(fēng) 海浪輕輕 拍醒我沉睡于 這掛滿憧...
    云山任野閱讀 165評(píng)論 1 2
  • 本周作業(yè)是使用理財(cái)app的感受投蝉,記得很久以前使用過隨手記养葵,中途忘記什么原因停止了,現(xiàn)在記賬主要通過記賬本瘩缆,原因是...
    祁晶閱讀 159評(píng)論 0 0