LLDB tips总结

作者: 忧郁的小码仔 | 来源:发表于2016-01-22 09:45 被阅读340次

    LLDB是Xcode默认的调试器,与LLVM编译器一起是Xcode中最重要的部分,可以使用LLDB的一些命令来帮助我们调试bug。

    1. 关于.lldbinit

    LLDB每次启动都会加载~.lldbinit文件,一些全局初始化的设置可以写在这个文件里面。

    ~.lldbinit默认是不存在的,可以使用touch 命令创建

    2. thread backtrace命令  (缩写:bt)

    程序crash的时候,可以使用此命令来打印线程堆栈调用信息。 

    3.image lookup -a 地址命令

    当程序crash的时候,可以用此命令来查看某个地址对应在程序中的位置

    比如,

    用image命令打印crash堆栈信息(此处直接打印出错位置的地址)

    4. watchpoint set variable self->变量名 命令

    此命令可用来跟踪变量值的变化,每当变量的值被修改的时候,都会触发一次。

    比如:给namea属性添加一个watchpoint.


    添加一个watchpoint

    当点击按钮,修改namea属性的时候

    在按钮点击事件中修改namea属性的值 watchpoint被触发

    点击控制台第六个带向上箭头的按钮两次,第一次会跳到namea属性定义的地方,第二次会跳转到触发这次watchpoint的具体位置:如下:

    属性namea定义的地方 属性namea被修改的地方(watchpoint触发点)

    5. thread return 0/1 命令

    次命令会直接返回0/1,不再执行下面的语句。

    如下:


    用thread return 0 命令直接将按钮点击事件返回 点击第三个继续执行按钮即可

    6.expression -- 表达式 命令

    次命令可用来修改变量的值,以及执行表达式

    如下

    再比如程序运行中修改某个控件或view的样式(颜色)

    使用[CATransaction flush]命令可立即刷新界面

    7. 关于frame, bounds在lldb命令行不能打印的问题

    frame和bounds值直接打印是不okay的

    这是因为没有导入UIKit库的原因,执行下面命令即可

    问题是,这样就需要每次都要e @import UIKit。

    一开始的时候说过,lldb启动的时候会执行~.lldbinit文件里面的命令,我们可以将导入UIKit库的命令放到这个文件里面,但是,问题是UIKit库是在target里面的,而lldb启动加载.lldbinit的时候target还没有创建,所以无法import UIKit库,这里就需要用到另一个命令啦:stop-hook. 这个命令是不依赖target的

    在.lldbinit中添加如下命令:

    display @import UIKit

    target stop-hook add -o "target stop-hook disable"

    关闭工程,重新运行,再打断点,打印frame和bounds

    frame和bounds值可以打印Okay

    上面用到的两个命令:

    display 命令:它和p,e,expression是等效的,用来执行某一个命令

    target stop-hook命令:该命令可以让我们在每次breakpoint或watchpoint让程序stop的时候去执行一些命令。

    target stop-hook add 标示添加stop-hook,

    target stop-hook add -o   : -o 标示添加一条命令(--one-liner)

    target stop-hook disable:使所有的stop-hook失效  (enble作用相反)

    stop-hook list :用来查看所有的stop-hook

    target stop-hook disable id 可以使stop-hookid为2的stop-hook失效

    target stop-hook delete id: 删除stop-hook

    Undisplay id 是简写的删除命令。

    LLDB命令还有很多,可以用help命令自己进行查找和尝试:

    相关文章

      网友评论

      • UItachi:做一回伸手党:请问如何让lldb在用NSLog的时候自动将unicode转成中文打印出来
        C丶丶H:@UItachi 有插件
        忧郁的小码仔:@UItachi 这个没实现过哈,再查一下
      • b30280686e34:终于知道为什么不能打印属性了,谢谢
        忧郁的小码仔:@b30280686e34 呵呵,不客气。我也是看别人文章的。

      本文标题:LLDB tips总结

      本文链接:https://www.haomeiwen.com/subject/jailkttx.html