gcc -g main.c //在目标文件加入源代码的信息
gdb a.out (gdb) start //开始调试
(gdb) n //一条一条执行
(gdb) step/s //执行下一条,如果函数进入函数
(gdb) backtrace/bt //查看函数调用栈帧
(gdb) info/i locals //查看当前栈帧局部变量
(gdb) frame/f //选择栈帧,再查看局部变量
(gdb) print/p //打印变量的值
(gdb) finish //运行到当前函数返回
(gdb) set var sum= //修改变量值
(gdb) list/l 行号或函数名 //列出源码
(gdb) display/undisplay sum //每次停下显示变量的值/取消跟踪
(gdb) break/b 行号或函数名 //设置断点
(gdb) continue/c //连续运行
(gdb) info/i breakpoints //查看已经设置的断点
(gdb) delete breakpoints //删除某个断点
(gdb) disable/enable breakpoints //禁用/启用某个断点
(gdb) break if sum != //满足条件才激活断点
(gdb) run/r //重新从程序开头连续执行
(gdb) watch input[] //设置观察点
(gdb) info/i watchpoints //查看设置的观察点
(gdb) x/7b input //打印存储器内容,b--每个字节一组,7--7组
(gdb) disassemble //反汇编当前函数或指定函数
(gdb) si // 一条指令一条指令调试 而 s 是一行一行代码
(gdb) info registers // 显示所有寄存器的当前值
(gdb) x/ $esp //查看内存中开始的20个数
一、启动程序
如果在启动gdb时没有指明程序,可以使用命令file或exec-file加载程序;
run(r):
run(r)命令使程序启动,可以在run命令中指明程序参数;值得注意的是,首次运行run后,如果再次执行run并且不带参数,会以之前的参数运行程序。
set args:
指定程序的参数。set args后,run可以不带参数而以指定的参数运行程序。如果set args不太参数,清楚程序参数,执行run后程序不太参数运行。
在加载程序后,如果程序重新编译,gdb会根据符号文件的更改时间自动重载加载符号文件,所以,不需要重新加载文件。
start:
使用start命令使程序停在main函数的第一条语句。
二、调试已经在运行的程序
attach pid:
从ps获得进程号,通过attach命令连接到该进程。attach一个进程后,gdb首先stop该进程,这样就可以设置断点,执行step、continue等命令;如果执行r命令,会杀掉原来的进程。
detach:
释放该进程,原进程会继续执行。
三、调试多个inferiors和程序
gdb允许在一个会话下调试多个程序,比如一个进程fork出两个或者多个进程,或者把当前程序复制出一个副本,这些都是通过inferior实现控制。
info inferiors:
显示当前管理的inferiors。
inferior infono:
切换到对应的inferior。
add-inferior [-copies n] [-exec executable]:
添加n(默认为1)个inferior,如果指明executable文件,可以以后通过file加载符号文件。
clone-inferiror [-copies n] [infno]:
复制编号为infno(默认为当前)的inferior。
其它相关命令:
remove-inferiors infno
detach inferior infno
kill inferiors infno
maint info program-spaces
四、调试fork
默认情况下,当一个程序fork,gdb会跟踪父进程而子进程畅通无止的执行。如果在child中设置了一个断点,执行到断点处,child会收到一个SIGTRAP信号,默认为终止程序。
最开始调试child进程的方法是在child中设置一个sleep,然后通过attach连到child。
set follow-fork-mode mode
show follow-fork-mode:
在Linux2.5.46以后,gdb支持fork函数的调试;通过set-follow-mode命令,设置跟随parent还是child,如果不设置默认为跟随parent。
set detach-on-fork mode
show detach-on-fork:
在Linux,可以通过set detach-on fork off命令,在fork后,对parent和child都进行调试。父、子进程为多个inferiors,参见第三部分。
五、多线程调试
info threads:
显示线程信息。
thread thread-id:
切换到对应线程。
thread name [name]:
修改当前thread的名称。默认为程序名称。
六、Checkpoint
在Linux,gdb支持保留程序在某个时候的快照,除了进程号和已经输出的内容,所有状态恢复到快照状态。
通过以下命令实现快照。
checkpoing: 生成当前状态的快照
info checkpoint:显示快照信息
restart checkpoint-id:恢复到某个checkpoint
delete checkpoint checkpoint-id:删除某个checkpoint