使用gdb调试多线程程序总结,gdb调试多线程总结


转:使用gdb调试多线程程序总结

  一直对GDB多线程调试接触不多,最近因为工作有了一些接触,简单作点记录吧。 先介绍一下GDB多线程调试的基本命令。 info threads 显示当前可调试的所有线程,每个线程会有一个GDB为其分配的ID,后面操作线程的时候会用到这个ID。 前面有*的是当前调试的线程。 thread ID 切换当前调试的线程为指定ID的线程。 break thread_test.c:123 thread all在所有线程中相应的行上设置断点thread apply ID1 ID2 command 让一个或者多个线程执行GDB命令command。 thread apply all command 让所有被调试线程执行GDB命令command。 set scheduler-locking off|on|step 估计是实际使用过多线程调试的人都可以发现,在使用step或者continue命令调试当前被调试线程的时候,其他线程也是同时执行的,怎么只让被调试程序执行呢?通过这个命令就可以实现这个需求。off 不锁定任何线程,也就是所有线程都执行,这是默认值。 on 只有当前被调试程序会执行。 step 在单步的时候,除了next过一个函数的情况(熟悉情况的人可能知道,这其实是一个设置断点然后continue的行为)以外,只有当前线程会执行。

gdb对于多线程程序的调试有如下的支持:

  • 线程产生通知:在产生新的线程时, gdb会给出提示信息

(gdb) r

Starting program: /root/thread

[New Thread 1073951360 (LWP 12900)]

[New Thread 1082342592 (LWP 12907)]---以下三个为新产生的线程

[New Thread 1090731072 (LWP 12908)]

[New Thread 1099119552 (LWP 12909)]

  • 查看线程:使用info threads可以查看运行的线程。

(gdb) info threads   

4 Thread 1099119552 (LWP 12940)    0xffffe002 in ?? ()   

3 Thread 1090731072 (LWP 12939)    0xffffe002 in ?? ()   

2 Thread 1082342592 (LWP 12938)    0xffffe002 in ?? ()

* 1 Thread 1073951360 (LWP 12931)    main (argc=1, argv=0xbfffda04) at thread.c:21

(gdb)

注意,行首的蓝色文字为gdb分配的线程号,对线程进行切换时,使用该该号码,而不是上文标出的绿色数字。

另外,行首的红色星号标识了当前活动的线程

  • 切换线程:使用 thread THREADNUMBER 进行切换,THREADNUMBER 为上文提到的线程号。下例显示将活动线程从 1 切换至 4。

(gdb) info threads    

4 Thread 1099119552 (LWP 12940)    0xffffe002 in ?? ()    

3 Thread 1090731072 (LWP 12939)    0xffffe002 in ?? ()    

2 Thread 1082342592 (LWP 12938)    0xffffe002 in ?? ()

* 1 Thread 1073951360 (LWP 12931)    main (argc=1, argv=0xbfffda04) at thread.c:21

(gdb) thread 4

[Switching to thread 4 (Thread 1099119552 (LWP 12940))]#0    0xffffe002 in ?? ()

(gdb) info threads

* 4 Thread 1099119552 (LWP 12940)    0xffffe002 in ?? ()    

3 Thread 1090731072 (LWP 12939)    0xffffe002 in ?? ()    

2 Thread 1082342592 (LWP 12938)    0xffffe002 in ?? ()    

1 Thread 1073951360 (LWP 12931)    main (argc=1, argv=0xbfffda04) at thread.c:21 (gdb)

       以上即为使用gdb提供的对多线程进行调试的一些基本命令。另外,gdb也提供对线程的断点设置以及对指定或所有线程发布命令的命令。

       初次接触gdb下多线程的调试,往往会忽视gdb中活动线程的概念。一般来讲,在使用gdb调试的时候,只有一个线程为活动线程,如果希望得到其他的线程的输出结果,必须使用thread命令切换至指定的线程,才能对该线程进行调试或观察输出结果。

 

gdb调试主要命令:GDB调试程序


GDB下怎调试多线程程序?

可以使用gdb命令,调试多线程。
在调试的过程中,
可以输入命令:thread这是会列出多个线程的进程号。
然后你可以选择进入哪个线程进行调试。
只要输入:thread 线程进程号就可以了。
同单线程调试的方法没有多大区别。
请自己查看help命令。
请一定要加分啊。
 

gdb调试程序函数名为问号,什原因?

多线程程序运行一段时间产生core文件,gdb调试的时候显示发生了段错误,但定位不错段错误的位置,显示如下:[*]Program terminated with signal 11, Segmentation fault.[*]#0 0x47e10000 in ? ()[*](gdb) bt[*]#0 0x47e10000 in ? ()[*]#1 0x47e10000 in ? ()Backtrace stopped: previous frame identical to this frame (corrupt stack?)程序使用的动态库都已经通过set solib-absolute-prefix和set solib-search-path 命令设置好了,gdb的时候也没有提示找不到的符号之类的信息。但函数名却一直是问号,搞不懂什么原因。还有就是程序中没有递归调用为什么frame 0 与 frame 1的地址是一样的?除了使用gdb还有没有其他方法可以定位到出错的位置呢?
 

相关内容