LLDB指令

平时开发的过程中使用Xcode都是图形化操作习惯了,要是脱离了xcode你还能调试代码吗,恩,Xcode已经把我们惯坏了,不管怎样,作为一个开发对于了解图形操作背后的东西应该要了解。

申明:本文的[]都表示命令简写

一、增加方法断点

  • breakpoint set --name[-n] "方法名称"
  • breakpoint set --address[-a] 方法的内存地址
15428751580151.jpg

上面4个都是等价的,通过breakpoint list查看已经添加的断点

  • 模糊设置断点 breakpoint set -r 方法名称,r 是正则的意思

    (lldb) breakpoint set -r foo
    Breakpoint 2: 136 locations.
    

    发现有136个地方包含了foo字符串的方法,通过breakpoint list查看可以知道在哪里有这个方法,输出太多这边就截取一部分。

    (lldb) breakpoint list
    Current breakpoints:
    1: file = '/Users/fangshufeng/Desktop/thirdPart/image/Image/Image/ViewController.m', line = 24, exact_match = 0, locations = 1, resolved = 1, hit count = 2
    
      1.1: where = Image`-[ViewController touchesBegan:withEvent:] + 77 at ViewController.m:24, address = 0x000000010a4f768d, resolved, hit count = 2 
    
    2: regex = 'foo', locations = 136, resolved = 136, hit count = 2
      2.1: where = Image`-[ViewController foo] + 23 at ViewController.m:30, address = 0x000000010a4f76f7, resolved, hit count = 2 
      2.2: where = libbsm.0.dylib`au_print_xml_footer, address = 0x000000010ce5d665, resolved, hit count = 0 
      2.3: where = libsystem_kernel.dylib`proc_reset_footprint_interval, address = 0x000000010d5254ed, resolved, hit count = 0 
      
     [...]
      
    
  • 开关断点

    • breakpoint disable 断点编号(让某个断点不可用但是不是删除)
    • breakpoint enable 断点编号(让断点由不可用到可用)
    • breakpoint delete 断点编号 (删除断点不可恢复,需重新添加,不加编号则让你选择是否全部删除)
15428758913025.jpg

二、线程断点

源码调试

这个平时用的最多了,看下图

  • thread continue [continue] [c ] : 程序继续
  • thread step-over [next] [n] : 单步运⾏,把子函数当做整体⼀一步执行
  • thread step-in [step] [s] : 单步运⾏,遇到子函数会进入⼦函数
  • thread step-out [finish] : 直接执行完函数,返回函数调用处

太常用不贴代码了

15428763316698.jpg
  • thread backtrace [bt]:查看调用栈回溯
15428766389548.jpg

如图有时想查看代码的调用堆栈,但是xcode无法查看全,左边的地方只能看到部分,当然你可以点击这个地方,去查看。

15428767683217.jpg

也可以通过命令thread backtrace或者bt

15428770034517.jpg

frame为栈帧的意思,想了解函数栈帧的点击此处

  • frame variable :查看函数栈帧内的局部变量的值
(lldb) frame variable
(ViewController *) self = 0x00007fe390a04960
(SEL) _cmd = "touchesBegan:withEvent:"
(__NSSetM *) touches = 0x0000600003d30640 1 element
(UITouchesEvent *) event = 0x0000600000f66250
(int) a = 10

我们知道oc的方法内置了self_cmd参数,所以上面有self_cmd

汇编代码调试

开启汇编模式

15428781223072.jpg

和源码的区别是

  • ni : 单步运⾏,把子函数当做整体⼀一步执行
  • si: 单步运⾏,遇到子函数会进入⼦函数

三、内存断点

有时候想看某个内存发生改变的时候触发断点

  • watchpoint set variable 变量
  • watchpoint set variable 地址

我们给vc增加一个属性bar

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
    NSLog(@"fff");
    [self foo];
  
}


- (void)foo {
    NSLog(@"--foo--");
    NSLog(@"--foo2--");
    NSLog(@"--foo3--");
    
    for ( int i = 0; i < 3; i++) {
        self.bar += 10;
    }
}

通过该命令,每当内存地址内容被修改都会断到

15428798696567.jpg

还可以配合watchpoint command使用

  • watchpoint command add 断点编号:当内存断点触发的时候执行一些操作

每次改变都会输出值。


15428800472134.jpg
 watchpoint command add 1 // 1 表示 watchpoint 断点编号
Enter your debugger command(s).  Type 'DONE' to end.
> p self.bar;
> DONE // DONE 表示命令输入结束

相关指令如下,见名知意了不需要作介绍了

  • watchpoint list
  • watchpoint disable 断点编号
  • watchpoint enable 断点编号
  • watchpoint delete 断点编号
  • watchpoint command list 断点编号
  • watchpoint command delete 断点编号

四、不常用但很实用的指令

场景1:

15428794369809.jpg

要想代码执行到31行的断点的时候直接返回,不想执行后面的代码,就可以通过thread return指令,当代码执行到31行断点时,thread return可以实现。

场景2:有时崩溃了直接到main函数了,无法知道崩溃的地方

都知道下面的代码会崩溃

15428804652206.jpg

此时崩溃在下面的main函数处

15428805038949.jpg

终端输出信息

15428805244685.jpg

并不知道函数崩溃在哪一行可以使用image lookup指令

(lldb) image lookup -a 0x00000001022365db
      Address: Image[0x00000001000015db] (Image.__TEXT.__text + 203)
      Summary: Image`-[ViewController touchesBegan:withEvent:] + 139 at ViewController.m:30
      

发现崩溃在ViewControllertouchesBegan:withEvent:在30行处。

image lookup周边

  • image lookup -t 类:查看类的属性
(lldb) image lookup -t UIView
Best match found in /Users/fangshufeng/Library/Developer/Xcode/DerivedData/Image-cncplmezlusnyackyzpyppykazhf/Build/Products/Debug-iphonesimulator/Image.app/Image:
id = {0x00001063}, name = "UIView", byte-size = 8, decl = UIView.h:143, compiler_type = "@interface UIView : UIResponder
@property ( readonly,getter = layerClass,setter = <null selector>,nonatomic,class ) Class layerClass;
@property ( getter = isUserInteractionEnabled,setter = setUserInteractionEnabled:,assign,readwrite,nonatomic ) BOOL userInteractionEnabled;
@property ( getter = tag,setter = setTag:,assign,readwrite,nonatomic ) NSInteger tag;
@property ( readonly,getter = layer,setter = <null selector>,nonatomic ) CALayer * layer;
@property ( readonly,getter = canBecomeFocused,setter = <null selector>,nonatomic ) BOOL canBecomeFocused;
@property ( readonly,getter = isFocused,setter = <null selector>,nonatomic ) BOOL focused;
@property ( getter = semanticContentAttribute,setter = setSemanticContentAttribute:,assign,readwrite,nonatomic ) UISemanticContentAttribute semanticContentAttribute;
@property ( readonly,getter = effectiveUserInterfaceLayoutDirection,setter = <null selector>,nonatomic ) UIUserInterfaceLayoutDirection effectiveUserInterfaceLayoutDirection;
@end"
  • image lookup -n 方法名称:查看方法的位置
(lldb) image lookup -n foo
1 match found in /Users/fangshufeng/Library/Developer/Xcode/DerivedData/Image-cncplmezlusnyackyzpyppykazhf/Build/Products/Debug-iphonesimulator/Image.app/Image:
        Address: Image[0x0000000100001660] (Image.__TEXT.__text + 224)
        Summary: Image`-[ViewController foo] at ViewController.m:33
        
  • image lookup -o -f :可以查看内存的偏移量,这个再逆向中很常用

还有一些常见的指令比如ppoexpression就不说了。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,921评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,635评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,393评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,836评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,833评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,685评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,043评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,694评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,671评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,670评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,779评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,424评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,027评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,984评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,214评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,108评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,517评论 2 343

推荐阅读更多精彩内容

  • 常用指令 continue / c 执行到下一个断点 next / n 单步运行 把子函数当作整体 st...
    小狼_zy阅读 377评论 0 1
  • LLDB的Xcode默认的调试器,它与LLVM编译器一起,带给我们更丰富的流程控制和数据检测的调试功能。平时用Xc...
    小笨狼阅读 20,430评论 31 187
  •   LLDB的Xcode默认的调试器,它与LLVM编译器一起,带给我们更丰富的流程控制和数据检测的调试功能。平时用...
    Thinkdifferents阅读 1,500评论 1 4
  • 一、概述 LLDB全称 [ Low Level Debugger ], 默认内置于Xcode中的动态调试工具。标准...
    Superman168阅读 15,179评论 2 19
  • Xcode Debugging 你的代码,或者任何人的代码中总会有bug存在,你可以把调试看做是更好地理解代码的一...
    吃蘑菇De大灰狼阅读 2,435评论 0 2