相信大部分人都有使用過lldb命令進(jìn)行調(diào)試程序,如po
一個(gè)對(duì)象,打印出該對(duì)象的屬性僵闯,lldb是一個(gè)有著REPL的特性的開源調(diào)試器卧抗,還可以支持C++,Python插件。本文要講的就是利用Facebook開源的外部插件(Chisel)增強(qiáng)lldb的調(diào)試鳖粟。
1.安裝Chisel
奉上Chisel源碼地址
首先Chisel的安裝要使用homebrew社裆,homebrew安裝可以看這里,本文不多敘述
打開終端向图,輸入一下命令
brew update
brew install chisel
安裝完成后還要安裝日志提示在``/.lldbinit`添加一行泳秀,如果沒有該文件也可以新建一個(gè),然后重啟Xcode,令Chisel生效
2.使用Chisel
-
pvc
命令榄攀,該命令可以遞歸打印viewcontroller的層級(jí)嗜傅,利用該命令我們可以清楚的看到viewcontroller的層級(jí)結(jié)構(gòu),還可以查看view的加載情況。
pvc
<IWTabBarController 0x7fa5f3db2580>, state: appeared, view: <UILayoutContainerView 0x7fa5f3d32c80> | <UINavigationController 0x7fa5f4869000>, state: appeared, view: <UILayoutContainerView 0x7fa5f3df9ec0> | | <IWHomeViewController 0x7fa5f3db4eb0>, state: appeared, view: <UITableView 0x7fa5f4052e00> | <UINavigationController 0x7fa5f409d000>, state: disappeared, view: <UILayoutContainerView 0x7fa5f3c70930> not in the window | | <IWMessageViewController 0x7fa5f3e72520>, state: disappeared, view: (view not loaded) | <UINavigationController 0x7fa5f4868a00>, state: disappeared, view: <UILayoutContainerView 0x7fa5f3ececb0> not in the window | | <IWDiscoverViewController 0x7fa5f3e94990>, state: disappeared, view: (view not loaded) | <UINavigationController 0x7fa5f488e000>, state: disappeared, view: <UILayoutContainerView 0x7fa5f3f144b0> not in the window | | <IWMeViewController 0x7fa5f3ed4650>, state: disappeared, view: (view not loaded)
3.pviews
命令遞歸查看view的層級(jí)結(jié)構(gòu),打印出每個(gè)view的frame航攒,是否接受點(diǎn)擊等磺陡,方便調(diào)試。
pviews self.view
<UIView: 0x7fbbdb4c8ac0; frame = (0 0; 414 736); autoresize = W+H; layer = <CALayer: 0x7fbbdb4c7b30>> | <_UILayoutGuide: 0x7fbbdb4c8e90; frame = (0 0; 0 0); hidden = YES; layer = <CALayer: 0x7fbbdb4c7730>> | <_UILayoutGuide: 0x7fbbdb4c99e0; frame = (0 0; 0 0); hidden = YES; layer = <CALayer: 0x7fbbdb4c7a20>> | <UIView: 0x7fbbdb4cbf90; frame = (100 100; 150 150); layer = <CALayer: 0x7fbbdb4cb600>> | | <UILabel: 0x7fbbdb4c80a0; frame = (0 0; 100 100); text = 'chisel'; userInteractionEnabled = NO; layer = <_UILabelLayer: 0x7fbbdb4c8490>>
2.fv
和 fvc
漠畜,這兩個(gè)命令都是用來(lái)查看當(dāng)前內(nèi)存中存在的實(shí)例對(duì)象币他,其中fv是對(duì)view進(jìn)行搜索,而fvc是對(duì)viewcontroller進(jìn)行搜索憔狞,二者都支持正則搜索
(lldb) fv cus 0x7fd5aa63deb0 IWCustomerCell 0x7fd5aa537240 IWCustomerCell 0x7fd5aa7959e0 IWCustomerCell 0x7fd5aa793460 IWCustomerCell 0x7fd5aa7915c0 IWCustomerCell 0x7fd5aa78daf0 IWCustomerCell (lldb) fvc home 0x7fd5aa4aa340 IWHomeViewController
5.show
和hide
命令蝴悉,這兩個(gè)命令可以顯示或者隱藏某個(gè)viewOrLayer
6.caflush這個(gè)命令會(huì)重新繪制界面,當(dāng)你在調(diào)試界面顏色或者坐標(biāo)之類的時(shí)候可以直接在控制臺(tái)修改view的屬性瘾敢,然后caflush
就可以看到效果了
(lldb) p self.tview (UIView *) $2 = 0x00007f8651564a60 (lldb) e (void)[$1 setBackgroundColor:[UIColor greenColor]] (lldb) caflush
7,bmessage
該命令用于打斷點(diǎn)拍冠。在日常調(diào)試中,我們可能在[MyViewController viewWillAppear:]
中添加斷點(diǎn)調(diào)試,但是如果該方法沒有實(shí)現(xiàn)簇抵,通常做法是子類中實(shí)現(xiàn)庆杜,然后打斷點(diǎn)。現(xiàn)在使用bmessage
也可以試下調(diào)試功能(lldb) bmessage -[MyViewController viewWillAppear:]
,上面命令可以在其父類的viewWillAppear:
中打斷點(diǎn)碟摆,
8晃财,visualize
一個(gè)有意思的命令,它可以讓你使用預(yù)覽打開一個(gè) UIImage, CGImageRef, UIView, 或 CALayer。定位到每個(gè)view的具體情況
(lldb) visualize imageView
3,Last but the most important
Reference article
Debug of Xcode: Fix Console po frame Printing
Dancing in the Debugger — A Waltz with LLDB
Chisel official description