Chisel+LLDB 增強控制臺調試

相信大部分人都有使用過lldb命令進行調試程序,如po一個對象,打印出該對象的屬性,lldb是一個有著REPL的特性的開源調試器,還可以支持C++,Python插件。本文要講的就是利用Facebook開源的外部插件(Chisel)增強lldb的調試。

1.安裝Chisel

奉上Chisel源碼地址
首先Chisel的安裝要使用homebrew,homebrew安裝可以看這里,本文不多敘述
打開終端,輸入一下命令
brew update
brew install chisel

Chisel安裝日志

安裝完成后還要安裝日志提示在``/.lldbinit`添加一行,如果沒有該文件也可以新建一個,然后重啟Xcode,令Chisel生效

2.使用Chisel

  1. pvc命令,該命令可以遞歸打印viewcontroller的層級,利用該命令我們可以清楚的看到viewcontroller的層級結構,還可以查看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的層級結構,打印出每個view的frame,是否接受點擊等,方便調試。
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.fvfvc ,這兩個命令都是用來查看當前內存中存在的實例對象,其中fv是對view進行搜索,而fvc是對viewcontroller進行搜索,二者都支持正則搜索
(lldb) fv cus 0x7fd5aa63deb0 IWCustomerCell 0x7fd5aa537240 IWCustomerCell 0x7fd5aa7959e0 IWCustomerCell 0x7fd5aa793460 IWCustomerCell 0x7fd5aa7915c0 IWCustomerCell 0x7fd5aa78daf0 IWCustomerCell (lldb) fvc home 0x7fd5aa4aa340 IWHomeViewController
5.showhide命令,這兩個命令可以顯示或者隱藏某個viewOrLayer
6.caflush這個命令會重新繪制界面,當你在調試界面顏色或者坐標之類的時候可以直接在控制臺修改view的屬性,然后caflush就可以看到效果了
(lldb) p self.tview (UIView *) $2 = 0x00007f8651564a60 (lldb) e (void)[$1 setBackgroundColor:[UIColor greenColor]] (lldb) caflush
7,bmessage該命令用于打斷點。在日常調試中,我們可能在[MyViewController viewWillAppear:]中添加斷點調試,但是如果該方法沒有實現,通常做法是子類中實現,然后打斷點。現在使用bmessage也可以試下調試功能(lldb) bmessage -[MyViewController viewWillAppear:],上面命令可以在其父類的viewWillAppear:中打斷點,
8,visualize 一個有意思的命令,它可以讓你使用預覽打開一個 UIImage, CGImageRef, UIView, 或 CALayer。定位到每個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

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • iOS調試之chisel Chisel 是一個 LLDB 指令集合,用戶輔助 iOS 應用差錯。 安裝 chise...
    comst閱讀 4,645評論 0 13
  • [轉]淺談LLDB調試器文章來源于:http://www.cocoachina.com/ios/20150126/...
    loveobjc閱讀 2,573評論 2 6
  • LLDB的Xcode默認的調試器,它與LLVM編譯器一起,帶給我們更豐富的流程控制和數據檢測的調試功能。平時用Xc...
    CoderSC閱讀 1,381評論 0 2
  • 與調試器共舞 - LLDB 的華爾茲 nangege 2014/12/19 你是否曾經苦惱于理解你的代碼,而去嘗試...
    McDan閱讀 888評論 0 0
  • 相信大家肯定都有過為了調試而添加打印變量,或者使用直接常量代替函數調用結果,或者更改判斷條件以進入某特定分支的調試...
    縱橫而樂閱讀 2,002評論 0 3