IOS Xcode調試常用命令和斷點
Xcode 中的調試技巧與我們的日常開發息息相關,而這些調試技巧在我們解決Bug時,常常有事半功倍的作用,經常會用到的有各種斷點 和 命令。而這些調試技巧也經常會在面試中問到,所以不知道的就來看看吧。
調試命令
在上圖中,右側綠色區域就是Log 輸出區,在 Log 輸出區可以使用一些命令,來輔助調試。
那有哪些調試命令呢?
想要看所有的調試命令,可以在上圖的右側區域輸入help
,就會列出所有的調試命令。
本文就介紹幾個使用頻率比較高的,其他就查看后,自行了解吧。
1. p 命令
-- ('expression --') Evaluate an expression on the current thread. Displays any returned value with LLDB's default formatting.
p 命令是 print 命令的簡寫,使用p 命令可以查看基本數據類型的值,但是如果 使用 p 命令 查看的是對象,那么只會返回對象的指針地址。
p 命令后面除了可以接 變量、常量,還可以接 表達式。(❌但是不可以使用宏❌)
2. po 命令
po 命令可以理解為打印對象。功能與 p 命令類似,所以也是可以打印 常量、變量,打印表達式返回的對象等。(❌也不可以打印宏❌)
當然,這些打印功能,除了使用命令外,我們也可以使用左側區域,點擊變量右鍵―> print Description of “xxx”:
當然還有其他的打印方法:
3.expr 命令
expr 是 expression 的簡寫, 使用expr 命令,能夠在調試時,動態的執行賦值表達式,同時打印出結果。我們可以在調試時,動態的修改變量的值,這在調試想要讓應用執行異常路徑(如執行某個else 情況)很有用。
(lldb) p i (NSInteger) $16 = 1(lldb) expression i = 5(NSInteger) $17 = 5(lldb) po i 5
4.call 命令
上面是動態修改變量的值, Xcode 還支持動態調用函數。在控制臺執行該命令,可以在不修改代碼,不重新編譯的情況下,修改界面上的視圖。
這里有一個動態將cell 的某個子視圖移除的范例:
(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
命令 可以打印出線程的堆棧信息,該信息比左側的Debug Navigator 看到的還要詳細一些。
bt
命令是打印當前線程的堆棧信息
(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
命令可以列出當前App中的所有module(這個module 在后面符號斷點時有用到),可以查看某一個地址對應的代碼位置。
除了 image list
還有 image add
、image lookup
等命令,可以自行查看。
當遇到crash 時,查看線程棧,只能看到棧幀的地址,使用 image lookup 亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品午夜精品|
成人免费淫片aa视频免费|
国产日韩亚洲欧美|
欧美日韩一区二区三区在线免费观看|
亚洲人成77777在线观看网|
欧美亚洲国产视频|
欧美另类69精品久久久久9999|
亚洲图片欧美日产|
欧美精品在线播放|
啪一啪鲁一鲁2019在线视频|
清纯唯美日韩制服另类|
欧美日韩一区二区在线|
日韩精品中文字幕久久臀|
国产精品激情av电影在线观看|
北条麻妃99精品青青久久|
日韩三级影视基地|
欧美激情综合色|
欧美午夜激情小视频|
福利视频导航一区|
4444欧美成人kkkk|
日韩av网站大全|
欧美激情精品久久久久久黑人|
91亚洲国产成人久久精品网站|
欧美性猛交xxxx乱大交|
亚洲欧美精品中文字幕在线|
按摩亚洲人久久|
色婷婷亚洲mv天堂mv在影片|
亚洲专区国产精品|
国产精品入口福利|
午夜精品www|
亚洲第一综合天堂另类专|
亚洲国产成人精品女人久久久|
久久天天躁狠狠躁夜夜躁|
国产精彩精品视频|
亚洲第一免费网站|
国产精选久久久久久|
久久免费视频网站|
久久久国产在线视频|
欧美日韩加勒比精品一区|
91免费国产视频|
911国产网站尤物在线观看|
亚洲天堂男人天堂女人天堂|
精品久久中文字幕|
亚洲欧美国产精品专区久久|
成人黄色免费看|
伊人久久大香线蕉av一区二区|
亚洲国产精品美女|
日本一区二三区好的精华液|
狠狠色噜噜狠狠狠狠97|
久久久中文字幕|
日韩av网站在线|
波霸ol色综合久久|
2019中文字幕在线免费观看|
国产日韩欧美在线视频观看|
精品福利在线观看|
亚洲va欧美va在线观看|
久久999免费视频|
国产欧美日韩专区发布|
午夜精品一区二区三区在线播放|
一区二区三区视频免费|
国产91色在线|
欧美激情国产日韩精品一区18|
尤物九九久久国产精品的特点|
一个人看的www欧美|
人体精品一二三区|
亚洲wwwav|
欧美日韩在线观看视频|
国产成人在线一区|
亚洲伊人第一页|
亚洲国产精品va在线看黑人|
久久精品美女视频网站|
国产日本欧美一区二区三区|
亚洲天堂色网站|
久久视频免费在线播放|
成人啪啪免费看|
久久国产精品久久久久|
久久人人爽人人爽人人片av高请|
亚洲国产精品电影在线观看|
久久久久九九九九|
国产成人中文字幕|
日韩在线视频免费观看高清中文|
日韩精品极品在线观看播放免费视频|
欧洲午夜精品久久久|
久久精品久久久久电影|
亚洲大胆美女视频|
亚洲自拍偷拍网址|
91精品国产一区|
日韩欧美国产一区二区|
欧美精品在线第一页|
国产精品稀缺呦系列在线|
久久久在线免费观看|
国产精品一区二区三区免费视频|
精品成人国产在线观看男人呻吟|
久久人人看视频|
66m—66摸成人免费视频|
亚洲视频精品在线|
日韩亚洲精品电影|
91亚洲精品在线观看|
欧美性xxxx极品高清hd直播|
亚洲欧美日韩网|
国产三级精品网站|
91香蕉国产在线观看|
91超碰中文字幕久久精品|
亚洲精品免费网站|
亚洲精品国产精品国自产在线|
这里只有精品在线观看|
欧洲亚洲在线视频|
在线成人激情黄色|
91精品视频播放|
国产精品入口免费视频一|
久久视频在线视频|
欧美视频在线观看 亚洲欧|
一个人看的www欧美|
亚洲free性xxxx护士白浆|
亚洲精品视频免费在线观看|
欧美精品在线免费观看|
一区二区国产精品视频|
青青久久av北条麻妃海外网|
欧美精品在线免费|
亚洲精品欧美日韩专区|
91老司机精品视频|
国产极品精品在线观看|
欧美一级片在线播放|
中文字幕自拍vr一区二区三区|
欧美诱惑福利视频|
亚洲最大福利视频网站|
亚洲春色另类小说|
91久久精品日日躁夜夜躁国产|
国外成人性视频|
久久久久国色av免费观看性色|
欧美中文字幕视频在线观看|
这里只有视频精品|
欧美一区深夜视频|
欧美精品在线播放|
91成品人片a无限观看|
美女性感视频久久久|
一本大道久久加勒比香蕉|
欧美日韩国产限制|
国产精品 欧美在线|
国产精品美女网站|
精品国产福利在线|
亚洲午夜未删减在线观看|
欧美另类极品videosbest最新版本|
啪一啪鲁一鲁2019在线视频|
欧美成人精品在线播放|
国产成人一区三区|
成人激情视频在线观看|
欧美黑人xxxⅹ高潮交|
91精品在线一区|
538国产精品视频一区二区|
亚洲国产日韩欧美在线动漫|
亚洲在线免费观看|
欧美性生交xxxxx久久久|
一区二区三区www|
亚洲精品在线看|
国产精品www色诱视频|
68精品国产免费久久久久久婷婷|
久久精品国产精品|
亚洲自拍偷拍网址|
亚洲精品成人久久|
久久久精品2019中文字幕神马|
亚洲国产欧美一区二区三区久久|
91亚洲精品久久久久久久久久久久|
国产精品久久久久久av下载红粉|