gdb 调试多线程
如果目标进程已经core dump了,那么 gdb -c core xxx xxx是对应的程序文件。
如果目标进程还在运行,通常此时用于调试线程死锁的情况。有两种方法
一是 gdb -p xxx xxx是该进程的进程ID
或者用gcore xxx先获取对应进程的core,他会生成一个core文件 core.xxx
进入gdb后
(gdb) info threads
可以列出所有的线程,缺省设为当前的线程前面有一个*号
比如
gdb) info thread
9 system thread 154262 Priority:154 0xc00000000042f670:0 in __ksleep
+0x30 () from /usr/lib/hpux64/libc.so.1
4 system thread 153674 Priority:168 0xc0000000004367d0:0 in _nanosleep2_sys+0x30 () from /usr/lib/hpux64/libc.so.1
3 system thread 153673 Priority:168 0xc0000000004367d0:0 in _nanosleep2_sys+0x30 () from /usr/lib/hpux64/libc.so.1
2 system thread 153672 Priority:154 0xc00000000042f670:0 in __ksleep
+0x30 () from /usr/lib/hpux64/libc.so.1
* 1 system thread 153671 Priority:154 0xc000000000432ef0:0 in _read_sys
+0x30 () from /usr/lib/hpux64/libc.so.1
这是1个死锁的例子,可以看到线程9 和线程2都停在 __ksleep上。
如果想看各个线程的详细堆栈信息,比如要看9的
gdb)thread 9
把当前线程设成9,然后就可以查看相关信息
比如
gdb)bt
将列出栈的调用情况,以及对应源代码中的位置,此时谨慎察看对应代码,一般必有结果
http://blog.sina.com.cn/s/blog_62dc94eb0100flyn.html
gdb 调试多线程 神贴
时间: 2024-11-08 23:32:00
gdb 调试多线程 神贴的相关文章
关于gdb调试报错问题!!!!
问题描述 关于gdb调试报错问题!!!! Program received signal SIGSEGV, Segmentation fault. 0x000000332dc81484 in strncat () from /lib64/libc.so.6 之前并没有这个错误,但是我改了几个字符串之后就报错了,求助,在线等 解决方案 非法操作,需要看具体代码才能定位 解决方案二: GDB调试死机问题gdb 调试多线程程序 问题集锦gdb调试怪问题
编程-Linux中c语言多线程gdb调试“Cannot access memory at address”如何解决
问题描述 Linux中c语言多线程gdb调试"Cannot access memory at address"如何解决 程序的目的是做一个xml解析的工作. 部分代码如下: #define BUFLEN 10240 typedef struct buffer_t//需要操作的结构体 { char *buf; Bcsarray *bcsay; int bufnum; struct buffer_t *next; }databuf; databuf *buf, *bufs;//buf为链表
今天新装了个ubuntu用gdb调试时总是出这个问题,求大神给看看。
问题描述 今天新装了个ubuntu用gdb调试时总是出这个问题,求大神给看看. 最简单的程序,, 结果出了些这 解决方案 会不会是没有写return? 解决方案二: printf.c是系统c库实现,你可以直接跳出来,继续下一句代码调试.
利用GDB进行多线程调试
一.多线程调试 多线程调试重要就是下面几个命令: info thread 查看当前进程的线程. thread <ID> 切换调试的线程为指定ID的线程. break file.c:100 thread all 在file.c文件第100行处为所有经过这里的线程设置断点. set scheduler-locking off|on|step,这个是问得最多的.在使用step或者continue命令调试当前被调试线程的时候,其他线程也是同时执行的,怎么只让被调试程序执行呢?通过这个命令就可以实现这
Xcode的gdb调试
关于GDB 对于大多数Cocoa程序员来说,最常用的debugger莫过于Xcode自带的调试工具了.而实际上,它正是gdb的一个图形化包装.相对于gdb,图形化带来了很多便利,但同时也缺少了一些重要功能.而且在某些情况下,gdb反而更加方便.因此,学习gdb,了解一下幕后的实质,也是有必要的. gdb可以通过终端运行,也可以在Xcode的控制台调用命令.本文将通过终端讲述一些gdb的基本命令和技巧. 首先,我们来看一个例子: #import <Foundation/Foundation
比较全面的gdb调试命令
用GDB调试程序 GDB是一个强大的命令行调试工具.大家知道命令行的强大就是在于,其可以形成执行序列,形成脚本.UNIX下的软件全是命令行的,这给程序开发提代供了极大的便利,命令行软件的优势在于,它们可以非常容易的集成在一起,使用几个简单的已有工具的命令,就可以做出一个非常强大的功能. 于是UNIX下的软件比Windows下的软件更能有机地结合,各自发挥各自的长处,组合成更为强劲的功能.而Windows下的图形软件基本上是各自为营,互相不能调用,很不利于各种软件的相互集成.在这里并不是要和Win
《多核与GPU编程:工具、方法及实践》---- 3.9 调试多线程应用
3.9 调试多线程应用 调试多线程应用不仅仅是具备一个能够管理多线程的调试器.许多现代调试器支持线程的执行和独立调试,并支持指定线程的断点.观察窗等.本节不讨论调试器的具体实现方法.例如,图3-13展示了DDD--GNU DeBugger(GDB)前端,它执行代码清单3-24中公平的读者–写者解决方案.在UNIX/Linux中能够使用DDD和GDB(对于CLI困难)的唯一要求是在编译程序时添加调试支持选项,亦即使用编译器的-g开关. 多线程程序中的bug通常只有在与事件的某个精确时序有关的特定环
gdb调试命令的使用及总结
来源:http://www.jb51.net/article/36393.htm 参考:http://www.cnblogs.com/hankers/archive/2012/12/07/2806836.html 参考:http://wiki.ubuntu.org.cn/%E7%94%A8GDB%E8%B0%83%E8%AF%95%E7%A8%8B%E5%BA%8F 100个gdb技巧:https://github.com/hellogcc/100-gdb-tips/blob/master/sr
nginx模块_使用gdb调试nginx源码
工欲善其事必先利其器,如何使用调试工具gdb一步步调试nginx是了解nginx的重要手段. ps:本文的目标人群是像我这样初接触Unix编程的同学,如果有什么地方错误请指正. 熟悉gdb的使用 这里就不说了,谷歌一搜一堆,这里推荐一篇文章:GDB 命令详细解释 请重点看一下step,run,break,list,info,continue命令 下载nginx源码 这里使用nginx-1.0.14 src是源代码,auto文件夹是configure运行时候的各种命令集合 修改config并编译