斷點(diǎn)調(diào)試

轉(zhuǎn)載自http://supermao.cn/duan-dian-shen-ru-liao-jie/
轉(zhuǎn)載自http://supermao.cn/duan-dian-shen-ru-liao-jie/
轉(zhuǎn)載自http://supermao.cn/duan-dian-shen-ru-liao-jie/

編碼不能沒調(diào)試,調(diào)試不能沒斷點(diǎn)(Break Point)。XCode的斷點(diǎn)功能也是越來越強(qiáng)大。
基本斷點(diǎn)

如下圖,這種是最常用的斷點(diǎn),也是最容易設(shè)置。左鍵點(diǎn)擊一下就可以設(shè)置。
image

編輯斷點(diǎn)
斷點(diǎn)是可以編輯的。
image
image

斷點(diǎn)有下面幾個(gè)屬性可以設(shè)置:
Condition
Ignore
Action
Options

Condition
這里可以輸入條件表達(dá)式,滿足條件的時(shí)候斷點(diǎn)就會(huì)生效。例如上面輸入a == 50
。這個(gè)是非常有用的設(shè)置,特別在循環(huán)體內(nèi)調(diào)試的時(shí)候,用著真的是爽。
Ingore
在這里可以設(shè)置忽略斷點(diǎn)次數(shù)。
Action
Action是這里最復(fù)雜的,最強(qiáng)大的功能了。Action有6中類型。如下圖


image
image

AppleScript
Capture GPU Frame
Debugger Command
Log Message
Shell Command
Sound

常用的就是Log Message和Debugger Command
Log Message

在這里填寫的東西可以打印到控制臺(tái)。例如我做了如下設(shè)置
image
%B
會(huì)打印斷點(diǎn)的名字,%H

會(huì)打印斷點(diǎn)的調(diào)用次數(shù),@@
中間可以輸入表達(dá)式。 上面的設(shè)置在控制臺(tái)的輸出如下:
...-application:didFinishLaunchingWithOptions: 92 202015-07-28 22:19:21.905 Test[981:38016] 91 -application:didFinishLaunchingWithOptions: 93 20-application:didFinishLaunchingWithOptions: 94 20-application:didFinishLaunchingWithOptions: 95 202015-07-28 22:19:21.913 Test[981:38016] 92 2015-07-28 22:19:21.921 Test[981:38016] 93 2015-07-28 22:19:21.929 Test[981:38016] 94 -application:didFinishLaunchingWithOptions: 96 202015-07-28 22:19:21.937 Test[981:38016] 95 -application:didFinishLaunchingWithOptions: 97 202015-07-28 22:19:21.944 Test[981:38016] 96 -application:didFinishLaunchingWithOptions: 98 202015-07-28 22:19:21.952 Test[981:38016] 97 -application:didFinishLaunchingWithOptions: 99 202015-07-28 22:19:21.959 Test[981:38016] 98 -application:didFinishLaunchingWithOptions: 100 202015-07-28 22:19:21.967 Test[981:38016] 99

Debugger Command
這里可以輸入調(diào)試命令,也就是po
(打印對(duì)象信息),bt
(打印函數(shù)棧),expression
(表達(dá)式)這些調(diào)試命令。看圖就明白了:

image
控制臺(tái)輸出如下:
<UIApplication: 0x7fc92360b1d0>* thread #1: tid = 0xb7db, 0x0000000101d0eb11 Test-[AppDelegate application:didFinishLaunchingWithOptions:](self=0x00007fc923400570, _cmd=0x00000001033f3123, application=0x00007fc92360b1d0, launchOptions=0x0000000000000000) + 97 at AppDelegate.m:20, queue = 'com.apple.main-thread', stop reason = breakpoint 1.1 * frame #0: 0x0000000101d0eb11 Test-[AppDelegate application:didFinishLaunchingWithOptions:](self=0x00007fc923400570, _cmd=0x00000001033f3123, application=0x00007fc92360b1d0, launchOptions=0x0000000000000000) + 97 at AppDelegate.m:20 frame #1: 0x0000000102c0d748 UIKit-[UIApplication _handleDelegateCallbacksWithOptions:isSuspended:restoreState:] + 240 frame #2: 0x0000000102c0e357 UIKit-[UIApplication _callInitializationDelegatesForMainScene:transitionContext:] + 2540 frame #3: 0x0000000102c1119e UIKit-[UIApplication _runWithMainScene:transitionContext:completion:] + 1349 frame #4: 0x0000000102c10095 UIKit-[UIApplication workspaceDidEndTransaction:] + 179 frame #5: 0x0000000107d3c5e5 FrontBoardServices__31-[FBSSerialQueue performAsync:]_block_invoke_2 + 21 frame #6: 0x00000001024da41c CoreFoundationCFRUNLOOP_IS_CALLING_OUT_TO_A_BLOCK + 12 frame #7: 0x00000001024d0165 CoreFoundation__CFRunLoopDoBlocks + 341 frame #8: 0x00000001024cff25 CoreFoundation__CFRunLoopRun + 2389 frame #9: 0x00000001024cf366 CoreFoundationCFRunLoopRunSpecific + 470 frame #10: 0x0000000102c0fb02 UIKit-[UIApplication _run] + 413 frame #11: 0x0000000102c128c0 UIKitUIApplicationMain + 1282 frame #12: 0x0000000101d0edbf Testmain(argc=1, argv=0x00007fff5def13a8) + 111 at main.m:14 frame #13: 0x0000000104dbd145 libdyld.dylibstart + 1 frame #14: 0x0000000104dbd145 libdyld.dylibstart + 1(int) $2 = 982015-07-28 22:36:54.654 Test[1150:47067] 98 2015-07-28 22:36:54.670 Test[1150:47067] 99

Options
勾選Automatically continue after evaluating actions之后程序會(huì)在斷點(diǎn)產(chǎn)生后繼續(xù)運(yùn)行。這個(gè)屬性是相當(dāng)有用的,可以輸入調(diào)試信息至于不暫停程序。
出了上面的基本斷點(diǎn)外,XCode還提供了下面四種斷點(diǎn),需要點(diǎn)擊斷點(diǎn)面板左下角的+
號(hào)添加。


image

Exception Breakpoint
OpenGL ES Error Breakpoint
Symbolic Breakpoint
Test Failure Breakpoint

Exception Breakpoint

Exception Breakpoint是一個(gè)非常有用的斷點(diǎn)項(xiàng)。正如名字所示,當(dāng)程序拋出異常的時(shí)候就回產(chǎn)生斷點(diǎn)。通常程序崩潰會(huì)停在崩潰的地方,但有時(shí)候并不能準(zhǔn)確停在引起異常的地方。比如數(shù)組越界!比如我下圖所示,會(huì)引起數(shù)組越界訪問。
image
image
程序運(yùn)行的時(shí)候就會(huì)崩潰。但是崩潰停在了main函數(shù)里面,就算看了棧信息也不能馬上定位到到底是那個(gè)數(shù)組越界訪問了。為什么崩潰不能停在數(shù)組越界哪里?這是因?yàn)閿?shù)組越界訪問不一定會(huì)導(dǎo)致程序崩潰的,數(shù)組越界訪問會(huì)導(dǎo)致異常拋出,而拋出的異常沒有得到處理才會(huì)導(dǎo)致程序崩潰。因此最后會(huì)導(dǎo)致崩潰停在CoreFoundation框架里面。這個(gè)時(shí)候就需要設(shè)置Exception Breakpoint產(chǎn)生斷點(diǎn)來定位錯(cuò)誤了。
image
image

OpenGL ES Error Breakpoint
這個(gè)主要是OpenGL ES的斷點(diǎn)調(diào)試,這個(gè)個(gè)人沒用到過。
Symbolic Breakpoint

Symbolic Breakpoint,符號(hào)斷點(diǎn),真的是調(diào)試神器啊。當(dāng)程序運(yùn)行到特定符號(hào)的時(shí)候就會(huì)產(chǎn)生斷點(diǎn)。通過這種方式添加斷點(diǎn),就不需要在源文件中添加,也不需要知道斷點(diǎn)設(shè)置在文件的第幾行。如圖:
image

比普通斷點(diǎn)多了兩個(gè)屬性Symbol
和Module

Symbol
Symbol的內(nèi)容,可以有如下幾種: 1. 方法名稱:會(huì)對(duì)所有具有此方法名稱的類方法生效。例如 initWithFrame: 。 2. 特定類的方法:OC類和C++類都適用,例如 ,[UIView initWithFrame:]或者 Shap::draw()。 3. 函數(shù)名稱。例如普通C函數(shù)。

通過設(shè)置Symbol來調(diào)試,好用根本停不下來,想怎么斷點(diǎn)就怎么斷點(diǎn)。
Test Failure Breakpoint
這個(gè)類型的斷點(diǎn)會(huì)在test assertion 失敗的時(shí)候暫停程序的執(zhí)行。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,247評(píng)論 6 543
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,520評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,362評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,805評(píng)論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,541評(píng)論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,896評(píng)論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,887評(píng)論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,062評(píng)論 0 290
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,608評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,356評(píng)論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,555評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,077評(píng)論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,769評(píng)論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,175評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,489評(píng)論 1 295
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,289評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,516評(píng)論 2 379

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