美文网首页
【iOS开发】让lldb提升你的效率

【iOS开发】让lldb提升你的效率

作者: xiacheng | 来源:发表于2016-07-09 15:31 被阅读28次

    开发这么长时间,现在才知道原来有lldb这个东西,感觉真是找到救星了,以后再也不用再一个一个添加NSLog,然后再command+R来调试。

    简单的使用

    一般情况下,我们最常用的命令有三个,p, po, expr。
      p 其主要功能是输出原生类型(boolean、integer、float、etc)的信息。
      po 其主要功能是输出objective-c中对象(objects)的信息
      expr 在运行时修改变量的值。

    使用方法

    1、 **p, po **打印变量的值
    在xcode中打开一个app,在想要break的行号上单击,即可生成一个深色的箭头标识--断点。如下图,在viewDidLoad:中设置了断点。


    Xcode LLDB Debug

    运行app,等待。。。就可以看到xcode在断点处进入调试模式,现在让我们把视线移到xcode右下角的控制台,有木有看到(lldb)这样一行,鼠标移到此行,输入
    po [self view]
    回车,看看控制台上是不是多了一些view的信息,如下图:

    Xcode LLDB Debug
    po(printobject)是LLDB的一个命令,其主要功能是输出objective-c中对象(objects)的信息,与之相似的另外一个命令是p(print),其主要功能是输出原生类型(boolean、integer、float、etc)的信息。
    控制台输入
    p (int)[[[self view] subviews] count]
    结果如下(int) $2 = 2
    注意这个使用了类型转换告知调试器应该如何处理返回值。

    2、expr:运行时修改变量的值
    你以前怎么验证是不是某个变量的值导致整段程序不能正常工作?修改代码中的变量的值,然后cmd+r重新启动app?现在你不需要这么做了,只需要设置一个断点,当程序在这进入调试模式后,使用expr命令即可在运行时修改变量的值。
    假如有一个loginWithUsername:方法,需要两个参数:username,password。
    首先设置好断点,如下图所示:

    Xcode <wbr>LLDB <wbr>Debug教程
    运行app,进入断点模式后,在(lldb)后输入
    expr username =@"username"
    expr password =@"badpassword"
    

    控制台会返回以下信息

    (NSString *) $0 =0x3d3504c4 @"username"
    (NSString *) $1 =0x1d18ef60 @"badpassword"
    

    现在跳出断点,执行断点之后的两条输出语句,控制台会有以下输出

    (0x1c59aae0) A line for the breakpoint
    (0x1c59aae0) Username andPassword after: username:badpassword
    

    看到看吧,我们在运行时修改了变量的值,事情还可以变的更简单一些,我们可以编辑断点,让它自动填充需要的修改的变量的值,并且可以选择在此断点处不进入断点模式,仅仅修改指定变量的值,然后自动执行后续代码。
    右击断点选择“EditBreakpoint...”(或者按住cmd+option,单击断点),然后如下图所示设置断点

    Xcode <wbr>LLDB <wbr>Debug教程
    注意选中了最后一行(“Automatically continue afterevaluating”)的选择框,这就保证运行到这个断点的时,填充变量的值,然后继续运行,并不在此处断点进入调试模式。
    运行app,你会得到和上述手动设置变量的值一样的输出。
    接下来单击断点,使其处于禁用状态,现在箭头的颜色应该是浅蓝色的,重新运行app,你会发现username和password的值没有在运行时被改变了。

    3、设置断点触发条件
    断点的另外一个重要作用,是可以设置触发断点生效的条件,这样我们就可以在运行时针对特定的数据进行分析,观察app是否运行在正确的轨道上。如下图:

    Xcode <wbr>LLDB <wbr>Debug教程
    上述截图可以看到如下语句

    (BOOL)[(NSString*)[itemvalueForKey:@"ID"] isEqualToString:@"93306"]

    通过这行语句,我们告诉编译器:当item中ID等于93306时,此断点生效,进入断点调试模式。

    4、格式化输出数据
    如果你厌倦了代码里无穷无尽的NSLog,幸运的是我们可以在编辑断点使其输出格式化字符串就像平常编码时一样。不过有一点需要注意,平常编码时可能会使用NSString‘s stringWithFormat:输出格式化字符串,不过这个方法貌似在断点中木有效果,你需要使用alloc/init形式的方法,如下:
    po [[NSString alloc]initWithFormat:@"Item index is:%d", index]

    Xcode <wbr>LLDB <wbr>Debug教程 运行app,就能在控制台看到想要的输出啦!
    简单!强大!这就是LLDB给你的选择,从此代码里可以不用再有NSLog满天飞的情况了,代码变得更干净了,心情变得更愉悦了!
    LLDB还有很多强大的地方。
    如果想要有更了了解可以搜索这篇文章:
    浅谈LLDB调试器
    熟练使用 LLDB,让你调试事半功倍

    相关文章

      网友评论

          本文标题:【iOS开发】让lldb提升你的效率

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