欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

IOS Xcode調(diào)試常用命令和斷點(diǎn)整理

 更新時(shí)間:2016年12月21日 09:40:21   作者:Haley_Wong  
這篇文章主要介紹了IOS Xcode調(diào)試常用命令和斷點(diǎn)整理的相關(guān)資料,這里對(duì)IOS Xcode調(diào)試常用命令進(jìn)行了總結(jié),需要的朋友可以參考下

IOS Xcode調(diào)試常用命令和斷點(diǎn)

Xcode 中的調(diào)試技巧與我們的日常開發(fā)息息相關(guān),而這些調(diào)試技巧在我們解決Bug時(shí),常常有事半功倍的作用,經(jīng)常會(huì)用到的有各種斷點(diǎn) 和 命令。而這些調(diào)試技巧也經(jīng)常會(huì)在面試中問到,所以不知道的就來看看吧。
調(diào)試主要觀看區(qū)

調(diào)試命令

在上圖中,右側(cè)綠色區(qū)域就是Log 輸出區(qū),在 Log 輸出區(qū)可以使用一些命令,來輔助調(diào)試。
那有哪些調(diào)試命令呢?

想要看所有的調(diào)試命令,可以在上圖的右側(cè)區(qū)域輸入help,就會(huì)列出所有的調(diào)試命令。

本文就介紹幾個(gè)使用頻率比較高的,其他就查看后,自行了解吧。

1. p 命令

-- ('expression --') Evaluate an expression on the current thread.
           Displays any returned value with LLDB's default formatting.

p 命令是 print 命令的簡寫,使用p 命令可以查看基本數(shù)據(jù)類型的值,但是如果 使用 p 命令 查看的是對(duì)象,那么只會(huì)返回對(duì)象的指針地址。

p 命令后面除了可以接 變量、常量,還可以接 表達(dá)式。(❌但是不可以使用宏❌)

2. po 命令

po 命令可以理解為打印對(duì)象。功能與 p 命令類似,所以也是可以打印 常量、變量,打印表達(dá)式返回的對(duì)象等。(❌也不可以打印宏❌)

p 和 po 使用范例

當(dāng)然,這些打印功能,除了使用命令外,我們也可以使用左側(cè)區(qū)域,點(diǎn)擊變量右鍵—> print Description of “xxx”:
Paste_Image.png

當(dāng)然還有其他的打印方法:

3.expr 命令

expr 是 expression 的簡寫, 使用expr 命令,能夠在調(diào)試時(shí),動(dòng)態(tài)的執(zhí)行賦值表達(dá)式,同時(shí)打印出結(jié)果。我們可以在調(diào)試時(shí),動(dòng)態(tài)的修改變量的值,這在調(diào)試想要讓應(yīng)用執(zhí)行異常路徑(如執(zhí)行某個(gè)else 情況)很有用。

(lldb) p i 
(NSInteger) $16 = 1
(lldb) expression i = 5
(NSInteger) $17 = 5
(lldb) po i 
5

4.call 命令

上面是動(dòng)態(tài)修改變量的值, Xcode 還支持動(dòng)態(tài)調(diào)用函數(shù)。在控制臺(tái)執(zhí)行該命令,可以在不修改代碼,不重新編譯的情況下,修改界面上的視圖。

這里有一個(gè)動(dòng)態(tài)將cell 的某個(gè)子視圖移除的范例:

(lldb) po cell.contentView.subviews
<__NSArrayM 0x60800005f5f0>(
<UILabel: 0x7f91f4f18c90; frame = (5 5; 300 25); text = '2 - Drawing index is top ...'; userInteractionEnabled = NO; tag = 1; layer = <_UILabelLayer: 0x60800009ff40>>,
<UIImageView: 0x7f91f4d20050; frame = (105 20; 85 85); opaque = NO; userInteractionEnabled = NO; tag = 2; layer = <CALayer: 0x60000003ff60>>,
<UIImageView: 0x7f91f4f18f10; frame = (200 20; 85 85); opaque = NO; userInteractionEnabled = NO; tag = 3; layer = <CALayer: 0x608000039860>>
)

(lldb) call [label removeFromSuperview]
(lldb) po cell.contentView.subviews
<__NSArrayM 0x600000246de0>(
<UIImageView: 0x7f91f4d20050; frame = (105 20; 85 85); opaque = NO; userInteractionEnabled = NO; tag = 2; layer = <CALayer: 0x60000003ff60>>,
<UIImageView: 0x7f91f4f18f10; frame = (200 20; 85 85); opaque = NO; userInteractionEnabled = NO; tag = 3; layer = <CALayer: 0x608000039860>>
)

5.bt命令

bt 命令 可以打印出線程的堆棧信息,該信息比左側(cè)的Debug Navigator 看到的還要詳細(xì)一些。

bt 命令是打印當(dāng)前線程的堆棧信息

(lldb) bt 
* thread #1: tid = 0x27363, 0x000000010d204125 TestDemo`-[FifthViewController tableView:cellForRowAtIndexPath:](self=0x00007f91f4e153c0, _cmd="tableView:cellForRowAtIndexPath:", tableView=0x00007f91f5889600, indexPath=0xc000000000400016) + 2757 at FifthViewController.m:91, queue = 'com.apple.main-thread', stop reason = breakpoint 6.1
 * frame #0: 0x000000010d204125 TestDemo`-[FifthViewController tableView:cellForRowAtIndexPath:](self=0x00007f91f4e153c0, _cmd="tableView:cellForRowAtIndexPath:", tableView=0x00007f91f5889600, indexPath=0xc000000000400016) + 2757 at FifthViewController.m:91
  frame #1: 0x0000000111d0a7b5 UIKit`-[UITableView _createPreparedCellForGlobalRow:withIndexPath:willDisplay:] + 757
  frame #2: 0x0000000111d0aa13 UIKit`-[UITableView _createPreparedCellForGlobalRow:willDisplay:] + 74
  frame #3: 0x0000000111cde47d UIKit`-[UITableView _updateVisibleCellsNow:isRecursive:] + 3295
  frame #4: 0x0000000111d13d95 UIKit`-[UITableView _performWithCachedTraitCollection:] + 110
  frame #5: 0x0000000111cfa5ef UIKit`-[UITableView layoutSubviews] + 222
  frame #6: 0x0000000111c61f50 UIKit`-[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 1237
  frame #7: 0x00000001117a5cc4 QuartzCore`-[CALayer layoutSublayers] + 146
  frame #8: 0x0000000111799788 QuartzCore`CA::Layer::layout_if_needed(CA::Transaction*) + 366
  frame #9: 0x0000000111799606 QuartzCore`CA::Layer::layout_and_display_if_needed(CA::Transaction*) + 24
  frame #10: 0x0000000111727680 QuartzCore`CA::Context::commit_transaction(CA::Transaction*) + 280
  frame #11: 0x0000000111754767 QuartzCore`CA::Transaction::commit() + 475
  frame #12: 0x00000001117550d7 QuartzCore`CA::Transaction::observer_callback(__CFRunLoopObserver*, unsigned long, void*) + 113
  frame #13: 0x0000000110743e17 CoreFoundation`__CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 23
  frame #14: 0x0000000110743d87 CoreFoundation`__CFRunLoopDoObservers + 391
  frame #15: 0x0000000110728b9e CoreFoundation`__CFRunLoopRun + 1198
  frame #16: 0x0000000110728494 CoreFoundation`CFRunLoopRunSpecific + 420
  frame #17: 0x0000000114390a6f GraphicsServices`GSEventRunModal + 161
  frame #18: 0x0000000111b9d964 UIKit`UIApplicationMain + 159
  frame #19: 0x000000010d21294f TestDemo`main(argc=1, argv=0x00007fff529fe620) + 111 at main.m:14
  frame #20: 0x000000011458a68d libdyld.dylib`start + 1
(lldb) 

bt all 命令是打印所有線程的堆棧信息。打印出來的信息太多,就不展示了!

6.image 命令

image list 命令可以列出當(dāng)前App中的所有module(這個(gè)module 在后面符號(hào)斷點(diǎn)時(shí)有用到),可以查看某一個(gè)地址對(duì)應(yīng)的代碼位置。

除了 image list 還有 image add、image lookup等命令,可以自行查看。

當(dāng)遇到crash 時(shí),查看線程棧,只能看到棧幀的地址,使用 image lookup –address 地址 可以方便的定位到這個(gè)地址對(duì)應(yīng)的代碼行。

斷點(diǎn)

Xcode 中的斷點(diǎn)也是很有學(xué)問的,有普通斷點(diǎn)、條件斷點(diǎn)、符號(hào)斷點(diǎn)、異常斷點(diǎn)等很多種。

1.普通斷點(diǎn)

打一個(gè)普通斷點(diǎn),只需要找到對(duì)應(yīng)的行,在代碼左側(cè)(行號(hào)上)點(diǎn)擊一下即可。

2.條件斷點(diǎn)

條件斷點(diǎn)是一種很有用的斷點(diǎn),特別是在for 循環(huán)中。如果我們需要在i = 5 時(shí)添加斷點(diǎn),其他時(shí)候不加,那么就可以使用條件斷點(diǎn)。條件斷點(diǎn)是在普通斷點(diǎn)上 右鍵,選擇 Edit Breakpoint...,再設(shè)置一個(gè)條件即可

編輯普通斷點(diǎn)

添加條件

3.符號(hào)斷點(diǎn)

符號(hào)斷點(diǎn)就是 Symbolic Breakpoint,其實(shí)是針對(duì)某一個(gè)特定函數(shù)的斷點(diǎn),可以是一個(gè) OC函數(shù),也可以是 C++函數(shù)。 添加的地方如下:

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

符號(hào)斷點(diǎn)條件
Symbol 欄 可以填 [類名 方法名]或者 方法名 ,module 也是選填項(xiàng),它就是上面 image 命令中列出來的module。

例如 ,我們?nèi)绻惶钜粋€(gè)viewDidLoad,那么就會(huì)在所有類(包括第三方庫)的viewDidLoad 處打斷點(diǎn)。

符號(hào)斷點(diǎn)在調(diào)試一些沒有源碼的模塊時(shí)比較有用,比如調(diào)試一個(gè)第三方提供的Lib庫,或者系統(tǒng)的模塊,可以在相應(yīng)函數(shù)處下斷點(diǎn),可以大概調(diào)試清楚程序的運(yùn)行流程,也可以在斷點(diǎn)的時(shí)候查看到參數(shù)信息。

4.異常斷點(diǎn)

如果程序運(yùn)行就崩潰,我們可以打一個(gè)異常斷點(diǎn),這樣崩潰時(shí)就會(huì)觸發(fā)斷點(diǎn),很容易定位到問題所在,也能看到更多的崩潰相關(guān)信息,如Log,函數(shù)調(diào)用棧。
異常斷點(diǎn)

可以修改異常斷點(diǎn)的條件

注意: 有的程序或者有的功能可能會(huì)使用異常來組織程序邏輯,比如調(diào)用AVAudioPlayer ,運(yùn)行到 AVAudioPlayer 時(shí),就會(huì)導(dǎo)致斷點(diǎn)被觸發(fā)。我們可以修改 Exception 參數(shù),或者取消掉異常斷點(diǎn)來解決。

5.Watch 斷點(diǎn)

當(dāng)某個(gè)變量發(fā)生變化的時(shí)候會(huì)觸發(fā)。

創(chuàng)建一個(gè)Watch斷點(diǎn):

Watch 斷點(diǎn)

關(guān)于 Xcode 調(diào)試技巧中的 斷點(diǎn)和命令就先這么多了,其他有用到的以后再補(bǔ)充。

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

  • 詳解IOS的Automatically Sign在設(shè)備上打包

    詳解IOS的Automatically Sign在設(shè)備上打包

    本篇教程主要給大家分享了IOS的Automatically Sign如何在設(shè)備上直接打包,有需要的朋友參考學(xué)習(xí)下。
    2018-01-01
  • iOS判斷網(wǎng)絡(luò)請(qǐng)求超時(shí)的方法

    iOS判斷網(wǎng)絡(luò)請(qǐng)求超時(shí)的方法

    本篇文章主要介紹了iOS判斷網(wǎng)絡(luò)請(qǐng)求超時(shí)的方法,現(xiàn)在分享給大家,也給大家做個(gè)參考。感興趣的小伙伴們可以參考一下。
    2016-12-12
  • iOS中常見的幾種加密方法總結(jié)

    iOS中常見的幾種加密方法總結(jié)

    這篇文章主要給大家介紹了關(guān)于iOS中常見的幾種加密方法,其中包括 base64加密、POST加密、Token值介紹、MD5加密--(信息-摘要算法) 哈希算法之一、時(shí)間戳密碼以及指紋識(shí)別等方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。
    2017-12-12
  • IOS內(nèi)存泄漏檢查方法及重寫MLeakFinder

    IOS內(nèi)存泄漏檢查方法及重寫MLeakFinder

    這篇文章主要介紹了IOS內(nèi)存泄漏檢查方法及如何重寫MLeakFinder,幫助ios開發(fā)者維護(hù)自身程序,感興趣的朋友可以了解下
    2021-04-04
  • iOS常用加密算法介紹和代碼實(shí)踐

    iOS常用加密算法介紹和代碼實(shí)踐

    這篇文章主要為大家詳細(xì)介紹了iOS常用加密算法介紹和代碼實(shí)踐,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • IOS計(jì)步器功能實(shí)現(xiàn)之Healthkit和CMPedometer

    IOS計(jì)步器功能實(shí)現(xiàn)之Healthkit和CMPedometer

    現(xiàn)在越來越多的人關(guān)注運(yùn)動(dòng)和健康,iOS系統(tǒng)也在很早的時(shí)候就自帶了健康A(chǔ)PP,下面詳細(xì)描述一下在我們開發(fā)中,怎么實(shí)現(xiàn)計(jì)步器功能。
    2016-08-08
  • 詳解iOS中多個(gè)網(wǎng)絡(luò)請(qǐng)求的同步問題總結(jié)

    詳解iOS中多個(gè)網(wǎng)絡(luò)請(qǐng)求的同步問題總結(jié)

    這篇文章主要介紹了詳解iOS中多個(gè)網(wǎng)絡(luò)請(qǐng)求的同步問題總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-05-05
  • iOS中block的定義與使用

    iOS中block的定義與使用

    蘋果官方文檔聲明,block是objc對(duì)象。下面這篇文章主要給大家介紹了關(guān)于iOS中block的定義與使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)各位iOS開發(fā)者具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • iOS如何用100行代碼實(shí)現(xiàn)簡單的抽屜效果

    iOS如何用100行代碼實(shí)現(xiàn)簡單的抽屜效果

    最近在網(wǎng)上看到一些抽屜效果,看起來很酷!很眩!但是,下不下來看代碼, 所以決定還是自己寫吧!!這篇文章通過近100行的代碼就實(shí)現(xiàn)了簡單的抽屜效果,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-10-10
  • iOS粒子路徑移動(dòng)效果 iOS實(shí)現(xiàn)QQ拖動(dòng)效果

    iOS粒子路徑移動(dòng)效果 iOS實(shí)現(xiàn)QQ拖動(dòng)效果

    這篇文章主要為大家詳細(xì)介紹了iOS粒子路徑移動(dòng)效果,iOS實(shí)現(xiàn)QQ拖動(dòng)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07

最新評(píng)論