gdb调试多进程和多线程命令(转)
1. 默认设置下,在调试多进程程序时GDB只会调试主进程。但是GDB(>V7.0)支持多进程的分别以及同时调试,换句话说,GDB可以同时调试多个程序。只需要设置follow-fork-mode(默认值:parent)和detach-on-fork(默认值:on)即可。
child on 只调试子进程
parent off 同时调试两个进程,gdb跟主进程,子进程block在fork位置
child off 同时调试两个进程,gdb跟子进程,主进程block在fork位置
设置方法:set follow-fork-mode [parent|child] set detach-on-fork [on|off]
查询正在调试的进程:info inferiors
切换调试的进程: inferior <infer number>
添加新的调试进程: add-inferior [-copies n] [-exec executable] ,可以用file executable来分配给inferior可执行文件。
其他:remove-inferiors infno, detach inferior
2. GDB默认支持调试多线程,跟主线程,子线程block在create thread。
查询线程:info threads
切换调试线程:thread <thread number>
例程:
#include <stdio.h>
#include <pthread.h> void processA();
void processB();
void * processAworker(void *arg); int main(int argc, const char *argv[])
{
int pid; pid = fork(); if(pid != )
processA();
else
processB(); return ;
} void processA()
{
pid_t pid = getpid();
char prefix[] = "ProcessA: ";
char tprefix[] = "thread ";
int tstatus;
pthread_t pt; printf("%s%lu %s\n", prefix, pid, "step1"); tstatus = pthread_create(&pt, NULL, processAworker, NULL);
if( tstatus != )
{
printf("ProcessA: Can not create new thread.");
} processAworker(NULL);
sleep();
} void * processAworker(void *arg)
{
pid_t pid = getpid();
pthread_t tid = pthread_self();
char prefix[] = "ProcessA: ";
char tprefix[] = "thread "; printf("%s%lu %s%lu %s\n", prefix, pid, tprefix, tid, "step2");
printf("%s%lu %s%lu %s\n", prefix, pid, tprefix, tid, "step3"); return NULL;
} void processB()
{
pid_t pid = getpid();
char prefix[] = "ProcessB: ";
printf("%s%lu %s\n", prefix, pid, "step1");
printf("%s%lu %s\n", prefix, pid, "step2");
printf("%s%lu %s\n", prefix, pid, "step3"); }
输出:
[cnwuwil@centos c-lab]$ ./test
ProcessA: step1
ProcessB: step1
ProcessB: step2
ProcessB: step3
ProcessA: thread step2
ProcessA: thread step3
ProcessA: thread step2
ProcessA: thread step3
调试:
1. 调试主进程,block子进程。
(gdb) set detach-on-fork off
(gdb) show detach-on-fork
Whether gdb will detach the child of a fork is off.
(gdb) catch fork
Catchpoint (fork)
(gdb) r
[Thread debugging using libthread_db enabled] Catchpoint (forked process ), 0x00110424 in __kernel_vsyscall ()
Missing separate debuginfos, use: debuginfo-install glibc-2.12-1.47.el6.i686
(gdb) break test.c:
Breakpoint at 0x8048546: file test.c, line .
(gdb) cont
[New process ]
[Thread debugging using libthread_db enabled] Breakpoint , main (argc=, argv=0xbffff364) at test.c:
Missing separate debuginfos, use: debuginfo-install glibc-2.12-1.47.el6.i686
(gdb) info inferiors
Num Description Executable
process /home/cnwuwil/labs/c-lab/test
* process /home/cnwuwil/labs/c-lab/test
2. 切换到子进程:
(gdb) inferior
[Switching to inferior [process ] (/home/cnwuwil/labs/c-lab/test)]
[Switching to thread (Thread 0xb7fe86c0 (LWP ))]
# 0x00110424 in ?? ()
(gdb) info inferiors
Num Description Executable
* process /home/cnwuwil/labs/c-lab/test
process /home/cnwuwil/labs/c-lab/test
(gdb) inferior
[Switching to inferior [process ] (/home/cnwuwil/labs/c-lab/test)]
[Switching to thread (Thread 0xb7fe86c0 (LWP ))]
# main (argc=, argv=0xbffff364) at test.c:
(gdb) info inferiors
Num Description Executable
process /home/cnwuwil/labs/c-lab/test
* process /home/cnwuwil/labs/c-lab/test
3. 设断点继续调试主进程,主进程产生两个子线程:
(gdb) break test.c:
Breakpoint at 0x804867d: file test.c, line . ( locations)
(gdb) cont
ProcessA: step1
[New Thread 0xb7fe7b70 (LWP )]
ProcessA: thread step2 Breakpoint , processAworker (arg=0x0) at test.c:
(gdb) info inferiors
Num Description Executable
process /home/cnwuwil/labs/c-lab/test
* process /home/cnwuwil/labs/c-lab/test
(gdb) info threads
Thread 0xb7fe7b70 (LWP ) 0x00110424 in __kernel_vsyscall ()
Thread 0xb7fe86c0 (LWP ) 0x00110424 in ?? ()
* Thread 0xb7fe86c0 (LWP ) processAworker (arg=0x0) at test.c:
4. 切换到主进程中的子线程,注意:线程2为前面产生的子进程
(gdb) thread
[Switching to thread (Thread 0xb7fe7b70 (LWP ))]# 0x00110424 in __kernel_vsyscall ()
(gdb) cont
ProcessA: thread step3
ProcessA: thread step2
[Switching to Thread 0xb7fe7b70 (LWP )] Breakpoint , processAworker (arg=0x0) at test.c:
(gdb) info threads
* Thread 0xb7fe7b70 (LWP ) processAworker (arg=0x0) at test.c:
Thread 0xb7fe86c0 (LWP ) 0x00110424 in ?? ()
Thread 0xb7fe86c0 (LWP ) 0x00110424 in __kernel_vsyscall ()
(gdb) thread
转自:http://blog.csdn.net/pbymw8iwm/article/details/7876797
gdb调试多进程和多线程命令(转)的更多相关文章
- gdb调试多进程和多线程命令
gdb调试多进程和多线程命令 来源:http://blog.csdn.net/pbymw8iwm/article/details/7876797 1. 默认设置下,在调试多进程程序时GDB只会调试主 ...
- [转]gdb调试多进程和多线程命令
1. 默认设置下,在调试多进程程序时GDB只会调试主进程.但是GDB(>V7.0)支持多进程的分别以及同时调试,换句话说,GDB可以同时调试多个程序.只需要设置follow-fork-mode( ...
- gdb常用命令及使用gdb调试多进程多线程程序
一.常用普通调试命令 1.简单介绍GDB 介绍: gdb是Linux环境下的代码调试⼯具.使⽤:需要在源代码⽣成的时候加上 -g 选项.开始使⽤: gdb binFile退出: ctrl + d 或 ...
- gdb常用命令及gdb调试多进程/线程程序&coredump
一.常用普通调试命令 1.简单介绍GDB 介绍: gdb是Linux环境下的代码调试⼯具.使⽤:需要在源代码⽣成的时候加上 -g 选项.开始使⽤: gdb binFile退出: ctrl + d 或 ...
- Gdb调试多进程程序
Gdb调试多进程程序 程序经常使用fork/exec创建多进程程序.多进程程序有自己独立的地址空间,这是多进程调试首要注意的地方.Gdb功能强大,对调试多线程提供很多支持. 方法1:调试多进程最土的办 ...
- 使用 GDB 调试多进程程序
使用 GDB 调试多进程程序 GDB 是 linux 系统上常用的调试工具,本文介绍了使用 GDB 调试多进程程序的几种方法,并对各种方法进行比较. 3 评论 田 强 (tianq@cn.ibm.co ...
- gdb调试多进程多线程程序
一.调试的指令 1.list命令 list linenum 显示程序第linenum行的周围的程序 list function 显示程序名为function的函数的源程序 list 显示当前行后面的源 ...
- 用GDB调试多进程程序
在子进程中sleep.然后attach上去. gdb --pid=123456 ps出子进程的id,gdb attach 进程号. http://www.ibm.com/developerworks/ ...
- GDB调试-从入门到实践
你好,我是雨乐! 在上篇文章中,我们分析了线上coredump产生的原因,其中用到了coredump分析工具gdb,这几天一直有读者在问,能不能写一篇关于gdb调试方面的文章,今天借助此文,分享一些工 ...
随机推荐
- Codeforces 868A Bark to Unlock【字符串+二维string输入输出+特判】
A. Bark to Unlock time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...
- RabbitMQ (六) 订阅者模式之路由模式 ( direct )
路由模式下,生产者发送消息时需要指定一个路由键(routingKey),交换机只会把消息转发给包含该路由键的队列 这里,我们改变一下声明交换机的方式. 我们通过管理后台添加一个交换机. 添加后,生产者 ...
- Dumpzilla工具第615行bug的解决办法
Dumpzilla工具第615行bug的解决办法 在Dumpzilla使用选项frequency时,会提示SQL语法错误.这是由于其中SQL语句编写错误.需要将615行中: where url l ...
- Educational Codeforces Round 10 E - Pursuit For Artifacts (强联通缩点 + 回溯)
题目链接:http://codeforces.com/contest/652/problem/E 给你n个点m个边,x和y双向连接,要是z是1表示这条边上有宝藏,0则没有,最后给你起点和终点,问你要是 ...
- HTTP状态代码集
所有 HTTP 状态代码及其定义. 代码 指示 2xx 成功 200 正常:请求已完成. 201 正常:紧接 POST 命令. 202 正常:已接受用于处 ...
- Ze_Min Tree 主席树
前言 主席树,也叫可持久化线段树,所以他的本质是颗线段树,而可持久化指的是这颗线段树可以访问过去某个时刻线段树上的信息. 应用 应用的比较多的是查询区间的第k大值(因为其他的数据结构不好做). 实现 ...
- 【最短路】【Heap-dijkstra】Gym - 101147B - Street
按题意把图建出来跑最短路就行了.注意遮挡不会影响答案,所以不必考虑,因为走直线经过遮挡的时候,一定不会比答案更优. #include<cstdio> #include<algorit ...
- 【kd-tree】CDOJ - 1170 - 红与蓝
kd-tree模板题,对红点建立kd-tree,用每个蓝点查询,更新最小值即可. #include<cstdio> #include<cmath> #include<al ...
- JavaScript学习系列之执行上下文与变量对象篇
一个热爱技术的菜鸟...用点滴的积累铸就明日的达人 正文 在上一篇文章中讲解了JavaScript内存模型,其中有提到执行上下文与变量对象的概念.对于JavaScript开发者来说,理解执行上下文与变 ...
- 冒泡排序--注意flag变量的设置
代码: #include<stdio.h> void BubbleSort(int a[],int n){ int i,j; int temp; ; // 此处flag变量的设置可以提高算 ...