「运维经」第25章——gdb最实用的那几条命令

内容分享18小时前发布
0 0 0

实用调试操作

1 set scheduler-locking off|on

off 不锁定其他线程,默认
on 只让当前线程执行

2 disassemble

简写:disas
反汇编
使用方式
disassemble
disassemble $pc $pc+100
disassemble 开始地址 结束地址

3 source your_script

使用gdb脚本

4 -tui

显示代码

5 thread apply all command

所有线程执行command
查看所有线程的堆栈:thread apply all bt

6 info functions

输出所有函数

7 输出gdb log信息

set logging file
set logging on/off

8 info macro

查看这个宏在那些文件被引用了,以及宏定义是什么样子的。

9 macro –

查看宏展开的样子

10 自动化调试

(gdb) break func

Breakpoint 1 at 0x3475678: file test.c, line 12.

(gdb) command 1

Type commands for when breakpoint 1 is hit, one per line.

End with a line saying just “end”.

print arg1

print arg2

print arg3

end

(gdb)`

11 si

归纳:当要进入没有调试信息的库函数调试的时候,用si是唯一的方法。
当进入有调试信息的函数,用si和s都可以,但是他们不同,si是定位到汇编级别的第一个语句,但是s是进入到C级别的第一个语句

12 display/i $pc

执行si命令时打印汇编代码

13 gdb <program> <PID>

可以找到业务线程的pid/tid,然后通过pid attach上去。
再使用 set scheduler-locking on 堵塞其它线程。

14 p ‘f2.c’::x

file::variable
function::variable
可以通过这种形式指定你所想查看的变量,是哪个文件中的或是哪个函数中的。例如,查看文件f2.c中的全局变量x的值:

15 p *array@len

查看数组的值
有时候,你需要查看一段连续的内存空间的值。列如数组的一段,或是动态分配的数据的大小。你可以使用GDB的“@”操
作符,“@”的左边是第一个内存的地址的值,“@”的右边则你你想查看内存的长度。例如,你的程序中有这样的语句:
int *array = (int *) malloc (len * sizeof (int));
于是,在GDB调试过程中,你可以以如下命令显示出这个动态数组的取值:
p *array@len
二维数组打印
p **array@len
果是静态数组的话,可以直接用print数组名,就可以显示数组中所有数据的内容了。

16 return <返回值>

改变程序流程,直接结束当前函数,并将指定值返回

17 call func

在当前位置执行所要运行的函数

© 版权声明

相关文章

暂无评论

您必须登录才能参与评论!
立即登录
none
暂无评论...