gdb调试多进程程序

默认设置下我们在调试多进程程序时gdb志愿汇调试主进程,但是gdb(>v7.0)支持多进程的分别以及同时调试,换句话说,gdb可以同时调试多个程序。只需要设置follow-fork-mode(默认值:parent)和detach-on-fork(默认值:on)即可。
follow-fork-mode和detach-on-fork说明:

follow-fork-modedetach-on-fork说明
parenton只调试主进程(GDB默认)
childon只调试子进程
parentoff同时调试两个进程,gdb跟主进程,子进程block在fork位置
childoff同时调试两个进程,gdb跟子进程,主进程block在fork位置

我们先来了解下一些常见的选项:

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:单条执行

下面我就通过代码的形式对相关的指令进行使用:

 1 #include <stdio.h>
  2 #include <unistd.h>
  3 
  4 int main()
  5 {
  6     pid_t id=fork();
  7     if(id<0)
  8     {
  9         perror("fork");
 10         return 1;
 11     }
 12     else if(id==0)
 13     {
 14         int i=3;
 15         //子进程
 16         while(i)
 17         {
 18             printf("child: %d running!\n",getpid());
 19             sleep(1);
 20             i--;
 21         }
 22     }
 23     else
 24     {
 25         int i=2;
 26         while(i)
 27         {
 28             printf("parent :%d going to dead\n",getpid());
 29             i--;
 30             sleep(1);
 31         }
 32     }
 33     return 0;
 34 }                                

1>首先我们进入gdb调试模式
这里写图片描述
2>我们来查看系统默认的follow-fork-mode和detach-on-fork:

show follow-fork-mode
show detach-on-fork

这里写图片描述
由图我们可以得出的是此时是只调试主进程的。(也就是我们的父进程)。
3>接下来我们设置一下flolow-fork-mode和detach-on-fork:

set follow-fork-mode [parent|child]
set detach-on-fork[on|off]

这里写图片描述
此时设置以后,可同时调试两个进程:gdb跟子进程,父进程block在fork的位置

显示gdb调试的有inferior,gdb会为它们分配ID
info inferior
其中带有*的进程是正在调试的inferior
gdb将每一个被调试程序的执行状态记录在一个名为inferior的结构中
一般情况下一个inferior对应一个进程,每个不同的inferior有不同的地址空间
inferior有时会在进程没有启动的时候就存在

4、用l/list命令查看源代码(按enter翻页)并在相应位置下断点
这里写图片描述
下断点:
这里写图片描述
5、运行程序,查询正在调试的进程:
显示GDB调试的所有inferior,GDB会为他们分配ID。其中带有*的进程是正在调试的inferior。( GDB将每一个被调试程序的执行状态记录在一个名为inferior的结构中。一般情况下一个inferior对应一个进程,每个不同的inferior有不同的地址空间。inferior有时候会在进程没有启动的时候就存在。)

run 运行程序
info inferiors 查询正在调试的进程

这里写图片描述
6> 切换调试的进程:

//切换调试的进程
inferior < infer number>

这里写图片描述

其他的命令

(1)add-inferior [-copies n] [-exec executable]

添加新的调试进程,可以用file executable来分配给inferior可执行文件。增加n个inferior并执行程序为executable。如果不指定n只增加一个inferior。如果不指定executable,则执行程序留空,增加后可使用file命令重新指定执行程序。这时候创建的inferior其关联的进程并没启动。

(2)remove-inferiors infno

删除一个infno号的inferior。如果inferior正在运行,则不能删除,所以删除前需要先kill或者detach这个inferior。

(3)clone-inferior [-copies n] [infno]

复制n个编号是infno的inferior。如果不指定n的话,就只复制一个inferior。如果不指定infno,则就复制正在调试的inferior。

(4)detach inferior

detach掉编号是infno的inferior。注意这个inferior还存在,可以再次用run命令执行它。

(5)kill inferior infno:

kill掉infno号inferior。注意这个inferior仍然存在,可以再次用run等命令执行它。

(6)set schedule-multiple on|off

设为off:只有当前inferior会执行。
设为on:全部是执行状态的inferior都会执行。
这个选项类似于多线程调试里的set .

(7)scheduler-locking

注意:如果scheduler-locking是指为on,即使schedule-multiple设置为on,也只有当前进程的当前线程会执行。
show schedule-multiple: 查看schedule-multiple的状态。

(8)set follow-exec-mode new|same

设置same:当发生exec的时候,在执行exec的inferior上控制子进程。
设置为new:新建一个inferior给执行起来的子进程。而父进程的inferior仍然保留,当前保留的inferior的程序状态是没有执行。

(9)show-exec-mode

查看follow-exec-mode设置的模式。

(10)set print inferior-events on|off

用来打开和关闭inferior状态的提示信息。

(11)show print inferior-events

查看print inferior-events设置的状态。

(12)maint info program-spaces

用来显示当前GDB一共管理了多少地址空间。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值