成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

iOS調(diào)試技巧:如何利用LLDB來Debug

移動(dòng)開發(fā) iOS
本篇文章主要是講解在開發(fā)中如何利用LLDB來Debug,一些調(diào)試命令可以幫助我們開發(fā)者更快更好地定位到問題所在。首先會(huì)講一些基礎(chǔ)知識(shí),主要是幫助新手們學(xué)習(xí)如何去調(diào)試。

 

[[163282]] 

前言

在開發(fā)中一定需要到調(diào)試跟蹤,但是很多開發(fā)者雖然做過很多的項(xiàng)目,但是未必了解開發(fā)中有哪些調(diào)試命令可以幫助我們開發(fā)者更快更好地定位到問題所在。

本篇文章主要是講解在開發(fā)中如何利用LLDB來Debug。首先會(huì)講一些基礎(chǔ)知識(shí),主要是幫助新手們學(xué)習(xí)如何去調(diào)試。對(duì)于一些比較高級(jí)的操作,不會(huì)也沒有關(guān)系,但是如果能夠掌握得了的話,會(huì)更方便更快速地查找問題。
 

初步認(rèn)識(shí)LLDB

LLDB是XCode內(nèi)置的為我們開發(fā)者提供的調(diào)試工具。至于還不懂什么是調(diào)試的,百度一下概念吧,筆者也不知如何描述。看看下圖吧,應(yīng)該就可以大概明白什么是調(diào)試了!

我們加了斷點(diǎn),然后在運(yùn)行到斷點(diǎn)處就停了下來,接下來我們看到lldb這里了嗎?我們可以通過lldb所提供的命令來操作。 

基本調(diào)試操作

從上圖中,我們八個(gè)按鈕,我們講講前五個(gè)按鈕:

***個(gè)按鈕點(diǎn)擊就會(huì)收起這一欄目了,也就看不見了。

第二個(gè)按鈕:如果為藍(lán)色,就是斷點(diǎn)有效。如果點(diǎn)擊它變成灰色,就是所有斷點(diǎn)不起作用。

第三個(gè)按鈕:是繼續(xù)的意思,會(huì)讓程序從斷點(diǎn)處恢復(fù)繼續(xù)往下運(yùn)行,我們點(diǎn)了這個(gè)按鈕后,應(yīng)用就會(huì)恢復(fù)正常運(yùn)行狀態(tài)。

第四個(gè)按鈕是:單步執(zhí)行的意思,每點(diǎn)這個(gè)按鈕一次,程序就會(huì)從我們斷點(diǎn)開始的地方,向下執(zhí)行一步。

第五個(gè)按鈕是:進(jìn)入執(zhí)行的意思,簡單來說就是如果我們當(dāng)前的斷點(diǎn)在一個(gè)函數(shù)調(diào)用上,把么斷點(diǎn)會(huì)繼續(xù)進(jìn)入這個(gè)函數(shù)的內(nèi)部進(jìn)行調(diào)試。

第六個(gè)按鈕是:跳出的意思, 就是如果我們當(dāng)前在一個(gè)函數(shù)中,它會(huì)跳出當(dāng)前的函數(shù),回到函數(shù)的調(diào)用處。

常用p、po、call命令

先看下圖:

 

以下是輸入help命令時(shí)打印出來的,可以看看這四者有什么不同:

  1. p         -- ('expression --')  Evaluate an expression (ObjC++ or Swift) in  
  2.                the current program context, using user defined variables and  
  3.                variables currently in scope.  
  4. po        -- ('expression -O  -- ')  Evaluate an expression (ObjC++ or Swift)  
  5.                in the current program context, using user defined variables and  
  6.                variables currently in scope.  
  7. print     -- ('expression --')  Evaluate an expression (ObjC++ or Swift) in  
  8.                the current program context, using user defined variables and  
  9.                variables currently in scope.  
  10. call      -- ('expression --')  Evaluate an expression (ObjC++ or Swift) in  
  11.                the current program context, using user defined variables and  
  12.                variables currently in scope. 

從官方的描述來看,p、print、call是一樣的,但是po就不太一樣了,輸入一樣但是輸出不一樣。po的輸出的是具體對(duì)象的內(nèi)容。

如果想要按照特定的格式來打印,如下:

  1. (lldb) p/s blogName  
  2. (__NSCFConstantString *) $9 = @"標(biāo)哥的技術(shù)博客"  
  3. (lldb) p/x blogName  
  4. (__NSCFConstantString *) $10 = 0x000000010921c0a8 @"標(biāo)哥的技術(shù)博客"  
  5. (lldb) p/t blogName  
  6. (__NSCFConstantString *) $11 = 0b0000000000000000000000000000000100001001001000011100000010101000 @"標(biāo)哥的技術(shù)博客"  
  7. (lldb) p/a blogName  
  8. (__NSCFConstantString *) $12 = 0x000000010921c0a8 @ @"標(biāo)哥的技術(shù)博客" 

關(guān)于這個(gè)規(guī)則問題,請(qǐng)查閱打印輸出格式化

lldb聲明變量

我們可以使用e命令定義變量,然后在調(diào)試中使用。看如下的例子:

  1. (lldb) e NSString *$str = @"http://www.henishuo.com"  
  2. (lldb) po $str  
  3. http://www.henishuo.com  
  4.    
  5. (lldb) e int $count = 10 
  6. (lldb) p $count  
  7. (int) $count = 10 
  8. (lldb) e NSArray *itemArray = @[@"Test", @"Demo", @"huangyibiao"]  
  9. (lldb) po $count  
  10. 10 

我們使用e聲明了str變量,然后下面就可以使用了。我們看到通過p命令打印出來的都是開頭的變量了嗎?我們?cè)诼暶骱褪褂脮r(shí)也需要加上$符號(hào),與PHP一樣!

在調(diào)試時(shí),有時(shí)候想臨時(shí)計(jì)算一下某個(gè)值來比較時(shí),就可以通過這種方式來實(shí)現(xiàn)了,再也不用到源代碼處添加上聲明實(shí)現(xiàn)然后添加一句打印了,是否便利了很多? 

調(diào)用變量的API

當(dāng)我們?cè)跀帱c(diǎn)處,定義了blogName變量了,因此我們可以通過調(diào)試命令來調(diào)用

  1. (lldb) po [blogName uppercaseString]  
  2. 標(biāo)哥的技術(shù)博客  
  3.    
  4. (lldb) po [blogName substringFromIndex:2]  
  5. 的技術(shù)博客 

強(qiáng)轉(zhuǎn)返回值類型

當(dāng)我們調(diào)用API返回值類型不指定時(shí),有時(shí)候所打印出來的東西是我們看不懂的,比如下面的獲取結(jié)果應(yīng)該是“標(biāo)”字,但是不同類型打印結(jié)果卻不一樣: 

  1. (lldb) po [blogName characterAtIndex:0]  
  2. 26631  
  3.    
  4. (lldb) po (unsigned int)[blogName characterAtIndex:0]  
  5. 26631  
  6.    
  7. (lldb) po (char)[blogName characterAtIndex:0]  
  8. 'a'  
  9.    
  10. (lldb) po (NSString *)[blogName characterAtIndex:0]  
  11. 0x0000000000006807  
  12.    
  13. (lldb) po (unichar)[blogName characterAtIndex:0]  
  14. U+6807 u'標(biāo)' 

加斷點(diǎn)

如果我們不是在一開始就添加所有的斷點(diǎn),而在調(diào)試開始后,想給其它地方加個(gè)斷點(diǎn),那么我們可以很方便地通過命令添加斷點(diǎn):

  1. (lldb) b ? 33  
  2. Breakpoint 9: where = OCLLDBDebugDemo`-[ViewController onButtonClicked:] + 53 at ViewController.m:33, address = 0x000000010921a6d5 

這是在當(dāng)前類文件下的33行添加一個(gè)斷點(diǎn),添加成功后會(huì)有提示,如這里的提示就是成功地在33行添加了斷點(diǎn)。當(dāng)然,添加斷點(diǎn)的方式也有好幾種,如: 

  1. (lldb) b ?-[ViewController onButtonClicked:]  
  2. Breakpoint 4: where = OCLLDBDebugDemo`-[ViewController onButtonClicked:] + 53 at ViewController.m:33, address = 0x000000010921a6d5 

實(shí)際也是在33行添加斷點(diǎn)。不過我們?nèi)粢褂脛?dòng)態(tài)添加斷點(diǎn),就使用b命令加行號(hào)就可以了,這種最簡單了。設(shè)置斷點(diǎn)觸發(fā)條件

看下圖,筆者是怎么設(shè)置觸發(fā)條件的:

 

我們?cè)贜SLog這一行,設(shè)置了條件,只有當(dāng)條件滿中時(shí),才會(huì)進(jìn)入斷點(diǎn),不過這里并沒有讓它進(jìn)入斷點(diǎn),而條件滿足時(shí)就發(fā)出聲音并打印提示語。

這種應(yīng)用場景主要是在循環(huán)遍歷數(shù)據(jù)時(shí),想要斷點(diǎn)跟蹤就只能通過這種方式了,除非添加NSLog打印,但是這種需要手動(dòng)添加代碼,在調(diào)試時(shí)才想到要添加一些打印語句,這時(shí)候又得重新運(yùn)行,這太慢了。如果懂得如何設(shè)置斷點(diǎn)條件,那么就能滿足我們的需求了,直接可以設(shè)置條件。
 

常用打印視圖層次結(jié)構(gòu)

當(dāng)我們想要知道某個(gè)視圖的結(jié)構(gòu)時(shí),可以通過調(diào)用recursiveDescription方法來打印出來,那么其結(jié)構(gòu)就一目了然了:
 

  1. (lldb) po [self.view recursiveDescription] ? | ? | ? ?| ? | ? ?| ? ?|(layer)  
  2.  ? | ? | 

臨時(shí)刷新界面UI

本demo中,最開始按鈕的背景顏色是blueColor,現(xiàn)在我們要在調(diào)試過程中修改其背景色為紅色,并刷新界面。執(zhí)行下面的命令行,App界面的按鈕背景顏色是:

 

 

 

  1. (lldb) e ((UIButton *)sender).backgroundColor = [UIColor redColor]  
  2. (UICachedDeviceRGBColor *) $41 = 0x00007fdd10715b00 
  3. (lldb) e (void)[CATransaction flush] 

執(zhí)行上面的命令后,App界面的按鈕背景顏色是:

這種做法很有用的哦。當(dāng)我們?cè)谡{(diào)試UI時(shí),因?yàn)轭伾愃贫蝗菀讌^(qū)分出來,但是我們可以在調(diào)試時(shí)通過這樣的方式來修改背景色,就不用給源代碼寫相應(yīng)的代碼來重新運(yùn)行看效果了。

在調(diào)試下運(yùn)行上面的命令后,按鈕的背景顏色就變成了紅色了!
***

寫下本篇文章的主要目的是小徒弟不太懂調(diào)試,寫下此篇文章以幫助小徒弟同時(shí)也幫助大家更好地在開發(fā)中學(xué)會(huì)去調(diào)試代碼。其實(shí)還有很多的調(diào)試命令,但是不常用,這里就不一一列出來講解了,大家若想了解更多,可以輸入help查看!
 

 

 

 

責(zé)任編輯:陳琳 來源: cocoachina
相關(guān)推薦

2019-04-26 06:58:56

iOSLLDBXcode

2013-05-17 10:54:37

iOS開發(fā)iOS SDK調(diào)試技巧

2013-07-31 13:36:07

Windows PhoVS調(diào)試技巧Windows Pho

2019-08-16 09:22:38

技術(shù)調(diào)試互聯(lián)網(wǎng)

2021-08-25 23:03:58

區(qū)塊鏈數(shù)據(jù)安全

2013-12-27 10:37:01

2014-08-12 11:21:32

2011-04-01 10:55:29

OSPFDebug

2020-07-19 08:15:41

PythonDebug

2021-08-26 05:04:53

JavaScript調(diào)試技巧

2021-12-13 09:13:48

網(wǎng)站數(shù)據(jù)客戶數(shù)據(jù)

2016-10-27 08:39:35

大數(shù)據(jù)設(shè)計(jì)定量

2024-03-07 13:35:44

數(shù)字鴻溝智慧城市人工智能

2011-07-08 18:34:34

iOS Debug Release

2019-09-04 11:14:44

物聯(lián)網(wǎng)分析物聯(lián)網(wǎng)商業(yè)價(jià)值

2017-07-17 06:46:06

2013-10-30 09:37:19

LinuxLinux命令

2020-06-02 10:30:02

MySQL DBAstrace數(shù)據(jù)庫

2019-06-14 14:15:07

Javascript調(diào)試技巧代碼

2013-04-18 10:19:40

iOS開發(fā)Xcode調(diào)試
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 99这里只有精品视频 | www.日日操 | 日本欧美大片 | 精品久久久网站 | 亚洲精品国产成人 | 亚洲国产精品一区二区三区 | 国产精品成人久久久久 | 18av在线播放 | 欧美一区二区三区免费电影 | 丁香五月缴情综合网 | 亚洲成人免费视频在线 | 91av大全| 色免费在线视频 | 草久久免费视频 | www.日本国产| 欧美性网 | 欧美亚洲在线 | 福利av在线 | 黄网站免费在线 | 激情五月婷婷综合 | 国产69精品久久久久777 | 欧美性生活一区二区三区 | 日韩电影中文字幕 | hitomi一区二区三区精品 | 作爱视频免费观看 | 中文字幕精品一区 | 天天拍天天射 | 黄色一级电影在线观看 | 午夜视频免费在线观看 | 精品中文在线 | 国产精品免费av | 天天干视频 | 国产精品色一区二区三区 | a级黄色毛片免费播放视频 国产精品视频在线观看 | 国产日韩精品在线 | 欧美性生交大片免费 | 欧洲精品在线观看 | 欧美国产精品久久久 | 嫩草研究影院 | 国产精品免费一区二区三区四区 | 色嗨嗨|