运维经–目录
实用调试操作
- set scheduler-locking off|on
off 不锁定其他线程,默认
on 只让当前线程执行
- disassemble
简写:disas
反汇编
使用方式
disassemble
disassemble $pc $pc+100
disassemble 开始地址 结束地址
- source your_script
使用gdb脚本
- -tui
显示代码
- thread apply all command
所有线程执行command
查看所有线程的堆栈:thread apply all bt
- info functions
输出所有函数
- 输出gdb log信息
set logging file
set logging on/off
- info macro
查看这个宏在那些文件被引用了,以及宏定义是什么样子的。
- macro -
查看宏展开的样子
- 自动化调试
(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)`
当我们的断点到达时,自动执行command中的三个命令,把func的三个参数值打出来。
- si
归纳:当要进入没有调试信息的库函数调试的时候,用si是唯一的方法。
当进入有调试信息的函数,用si和s都可以,但是他们不同,si是定位到汇编级别的第一个语句,但是s是进入到C级别的第一个语句
- display/i $pc
执行si命令时打印汇编代码
gdb <program> <PID>
可以找到业务线程的pid/tid,然后通过pid attach上去。
再使用 set scheduler-locking on 堵塞其它线程。
- p ‘f2.c’::x
file::variable
function::variable
可以通过这种形式指定你所想查看的变量,是哪个文件中的或是哪个函数中的。例如,查看文件f2.c中的全局变量x的值:
- p *array@len
查看数组的值
有时候,你需要查看一段连续的内存空间的值。比如数组的一段,或是动态分配的数据的大小。你可以使用GDB的“@”操
作符,“@”的左边是第一个内存的地址的值,“@”的右边则你你想查看内存的长度。例如,你的程序中有这样的语句:
int *array = (int *) malloc (len * sizeof (int));
于是,在GDB调试过程中,你可以以如下命令显示出这个动态数组的取值:
p *array@len
二维数组打印
p **array@len
果是静态数组的话,可以直接用print数组名,就可以显示数组中所有数据的内容了。
- return <返回值>
改变程序流程,直接结束当前函数,并将指定值返回
- call func
在当前位置执行所要运行的函数