GDB调试多进程与多线程

gdb调试过程中常用命令:

   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调试多进程:

#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/wait.h>
int main()
{
    pid_t pid = fork();
    if(pid == -1)
    {
        perror("fork error");
        return -1;
    }
    else if(pid == 0)
    {
        printf("i am a child:my pid is %d, my fatcher is %d\n", getpid(), getppid());
    }
    else
    {
        printf("i am father:my pid is %d\n", getpid());
        wait(NULL);
    }
    return 0;
}

 

默认条件下,在调试多进程时gdb只会调试主进程,可以进行设置

follow-fork-mode(默认:parent)

detach-on-fork(默认:on)

follow-fork-mode detach-on-fork 说明:

parent       on            只调试主进程(GDB默认)
child        on            只调试子进程
parent       off           同时调试两个进程,gdb跟主进程,子进程block在fork位置
child        off           同时调试两个进程,gdb跟子进程,主进程block在fork位置

1> 设置child off

 

2> 在主进程与子进程处打断点

 

3> 运行r

info inferiors

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

 

4> 切换调试的进程

inferior <infer number>

 

GDB调试多线程: 

#include <stdio.h>
#include <pthread.h>
void *thread1(void *arg)
{
    printf("i am thread1, my pid is %lu\n", pthread_self());
    return NULL;
}
void *thread2(void *arg)
{
    printf("i am thread2, my pid is %lu\n", pthread_self());
    return NULL;
}
int main()
{
    pthread_t pid1, pid2;
    pthread_create(&pid1, NULL, thread1, NULL);
    sleep(3);
    pthread_create(&pid2, NULL, thread2, NULL);

    pthread_join(pid1,NULL);
    pthread_join(pid2,NULL);
    return 0;
}

1> 在线程1,线程2处打断点

 

 

2> 查看线程

info threads

 

参考:

https://blog.csdn.net/weiyuefei/article/details/79790872

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值