list/l 行号:显示binFile源代码,接着上次的位置往下列,每次列10行。 list/l 函数名:列出某个函数的源代码。 r或run:运行程序。 s或step:进入函数调用 breaktrace(bt):查看各级函数调用及参数 info(i) locals:查看当前栈帧局部变量的值 info break :查看断点信息。 finish:执行到当前函数返回,然后挺下来等待命令 print(p):打印表达式的值,通过表达式可以修改变量的值或者调用函数 set var:修改变量的值 quit:退出gdb break(b) 行号:在某一行设置断点 break 函数名:在某个函数开头设置断点 continue(或c):从当前位置开始连续而非单步执行程序 run(或r):从开始连续而非单步执行程序 delete breakpoints:删除所有断点 delete breakpoints n:删除序号为n的断点 disable breakpoints:禁用断点 enable breakpoints:启用断点 info(或i) breakpoints:参看当前设置了哪些断点 display 变量名:跟踪查看一个变量,每次停下来都显示它的值 undisplay:取消对先前设置的那些变量的跟踪 until X行号:跳至X行 p 变量:打印变量值 n 或 next:单条执行“`
二、gdb调试多进程
1#include2#include3#include4#include56int main()7 {8 pid_t pid=fork();//creat child process910if(pid == -1)11 {12 perror("fork error");13return -1;14 }15elseif(pid == 0)//child16 {17printf("I am a child process:my pid is %d,my father pid is %d",getpi d(),getppid());18 }19else//father20 {2122printf("I am a father process:my pid is %d,my father pid is %d",getp id(),getppid());23 wait(NULL);//wait child process24 }25return0;2627 }
Makefile文件1 process : process.c2 gcc -o $@$^ -g 3 .PHONY:clean4clean:5 rm -f process
parent on :只调试主进程(GDB默认) child on :只调试子进程 parent off :同时调试两个进程,gdb跟主进程,子进程block在fork位置 chlid off :同时调试两个进程,gdb跟子进程,主进程block在fork位置
1>进入gdb调试模式
gdb process
2>查看系统默认的follow-fork-mode 与 detach-on-fork:
show follow-fork-mode show detach-on-fork
3>设置follow-fork-mode 与 detach-on-fork
set follow-fork-mode [parent|child] set detach-on-fork off[on|off]
(7)scheduler-locking1 //注意:如果scheduler-locking是指为on,即使schedule-multiple设置为on,也只有当前进程的当前线程会执行。 show schedule-multiple: 查看schedule-multiple的状态。
set scheduler-locking off|on|step: // 在调式某一个线程时,其他线程是否执行。在使用step或continue命令调试当前被调试线程的时候,其他线程也是同时执行的,如果我们只想要被调试的线程执行,而其他线程停止等待,那就要锁定要调试的线程,只让他运行。
off //不锁定任何线程,默认值。
on //锁定其他线程,只有当前线程执行。
step //在step(单步)时,只有被调试线程运行。
set non-stop on/off //当调式一个线程时,其他线程是否运行。
set pagination on/off: //在使用backtrace时,在分页时是否停止。
set target-async on/off //同步和异步。同步,gdb在输出提示符之前等待程序报告一些线程已经终止的信息。而异步的则是直接返回。