dailyLearning -- LLDB常用调试命令

LLDB

LLDB是一个命令行调试环境, 内置于Xcode的调试工具, 它与LLVM编译器一起, 带给我们更丰富的流程控制和数据检测的调试功能. 平时用Xcode运行程序, 实际走的都是LLDB. 熟练使用LLDB, 可以让你debug事半功倍.
LLDB对于命令的简称, 是头部匹配方式, 只要不混淆, 你可以随意简称某个命令. 结果为在xcode下验证所得, 可能与其它平台有所误差.
LLDB控制台平时会输出一些log信息. 如果我们想输入命令调试, 必须让程序进入暂停状态. 让程序进入暂停状态的方式主要有2种:

  1. 断点或者watchpoint: 在代码中设置一个断点(watchpoint). 当程序运行到断点位置的时候, 会进入stop状态
  2. 直接暂停, 控制台上方有一个暂停按钮, 上图红框已标出, 点击即可暂停程序.

1. 打印值,修改值,调用方法

1.1 p,po打印值
  • 打印相关的命令有:p,po

    p和po的区别在于使用po只会输出对应的值,而p则会返回值的类型以及命令结果的引用名。
    p 和 po命令
  • 对比结果:

PO:输出值
号码:输出值+值类型+引用名+内存地址(xcode中中有内存地址,其它平台不确定)

除此之外, 对还隐藏了一个有意思的功能, 常量的进制转换:
1.2 表达修改参数值

感觉EXP命令是调试过程中最有价值有命令了, 它可以打印值, 修改值.

expression 命令

表达:同样可以输出值+值类型+引用名 , 但其一般用于修改.

1.3 调用方法调用

在断点调用某个方法,并输出此方法的返回值

call 命令

表达:同样为输出值+值类型+引用名

2. 线程

2.1 堆栈打印线程回溯

如果嫌堆栈打印太长,可以加一个值限制,如bt 10,只打印
线程回溯 bt命令
2.2 线程返回跳出当前方法的执行

Debug的时候, 也许会因为各种原因, 我们不想让代码执行某个方法, 或者要直接返回一个想要的值. 这个时候就该线程返回上场了.

有返回值的方法里, 如: numberOfSectionsInTableView: 直接线程返回10, 就可以直接跳过方法执行, 返回10.
跳出 thread return 命令
2.3 流程控制

实际上使用的Xcode自带的可视化工具来控制“继续”,“暂停”,“下一步”,“进入”,“跳出”更简单.
流程控制命令
2.4 跳帧选择N

2.1中打印有10帧,如果我想跳转到第1帧:frame select 1
跳帧选择
2.5 查看帧变量

3. 图像

3.1 图像查找地址查找崩溃位置

当你遇见数组崩溃, 你又没有找到崩溃的位置, 只扔给你一堆报错信息, 这时候图像查询来帮助你

图像查找

寻找自己项目的标识,看到帧3位置,你只需这样查找位置:

项目中FW_MyHomeTableView.m:243

3.2 图像查找名称查找方法来源

此命令可以用来查找方法的来源包括在第三方SDK中的方法, 也能被查到.

例:查找transformOtherModelToSuit:
3.3 image lookup-type查看成员

查看某个类的所有属性和成员变量. 不过貌似框架库中文件不能查看.

4. 断点

4.1 文件名+行号断点集-f xxx -l xxx

我们平时操作的Xcode, 在某一行点下断点, 其实操作的就是这个命令.
4.2 函数名断点
4.2.1 方法名断点断点set -n方法名

提示:这里要说一下, xcode其实也有函数名断点, 不过用断点set -n实现, 比xcode下断点快N倍, 不过xcode下的断点还给提示所有断到的位置

4.2.2 类中方断断点集-n“ - [类名方法名]

注意: - [FW_MyHomeViewController viewDidLoad],外面一定要加双引号,不然会误识别为 - [FW_MyHomeViewController`

4.3 条件断点断点set -c“xxxx”

和xcode中符号断点功能相同,我在FW_HomeCell.m 362行下断点,但又想过滤宽度> 68的状态,操作如下:
4.4 查看断点列表断点列表
4.5 禁用/启用断点断点禁用/启用
4.6 移除断点断点删除
结语:

有了这些命令, 调试起来肯定就得心应手了总结下常用的:

  • 堆栈相关:bt查看堆栈,帧选择跳帧,帧变量查看帧参数,线程返回跳出当前执行,【step / finish / next / continue】进入/跳出/下一步/跳出本断点
  • 断点相关:断点集-f -l -c条件断点,断点集-n方法断点,断点删除断点移除,断点列表断点列表
  • image命令:image lookup -address崩溃定位,image lookup -name方法来源,image lookup-type查看成员
  • LLDB支持简写

Getting Started with LLDB

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

推荐阅读更多精彩内容

  • 丁酉清明,回乡祭祖,儿孙满堂,云集老屋,怀念亲人,情系故土。 坟前叩拜,泪流簌簌。 ...
    明烛高照阅读 488评论 0 3
  • 在看到本文之前,如果读者没看过笔者的前文Java实现Socket网络编程(三) ,请先翻阅。 下面,我们来实现服务...
    Louis_陆阅读 1,229评论 1 10
  • 周振璘10月份第十六次读书打卡,我读的书是《名校满分作文全集》,今天读了第100页到第 130 页,我最喜欢的文章...
    Jolin08阅读 205评论 0 0
  • 有这样一个故事,有三对新婚夫妇来到教堂祈祷,他们都说:上帝啊,请赐予我们一个孩子吧。于是上帝把三个天使变成三个...
    懵懂的丑猫阅读 241评论 0 1