以下是关于这次测试gdb调试多线程的代码
#include <stdio.h>
#include <pthread.h>
void* thread1(void* arg)
{
printf("I am thread1,my tid is %u\n",pthread_self());
return NULL;
}
void* thread2(void* arg)
{
printf("I am thread2,my tid is %u\n",pthread_self());
return NULL;
}
int main()
{
pthread_t tid1,tid2;
pthread_create(&tid1,NULL,thread1,NULL);
pthread_create(&tid2,NULL,thread2,NULL);
pthread_join(tid1,NULL);
pthread_join(tid2,NULL);
return 0;
}
1.首先使用gdb开始调试程序,输入info threads命令,该命令表示查看当前所有线程
现在因为还没有开始跑程序,所以gdb显示没有线程。
2.现在在主线程处下断点,并开始跑程序
现在因为还在主线程的开始处,并没有创建其余的两个线程,所以gdb显示只有一个线程即主线程
3.现在在另外两个线程函数的开始处下断点
输入c命令继续让程序继续执行,并查看当前的线程
蓝框部分我们可以看到,显示了一个新的线程,它的LWP是2729,正是底下ID为2的正在进行调试的线程的LWP,即thread1。最下面LWP为2705的线程即为主线程的LWP(之前的截图中有),LWP为2730的线程即为thread2。
4.继续输入c命令,让程序来到线程2处
此时正在调试的程序即为LWP为2730的thread2,因为thread1已经执行完毕,所以这里并没有显示thread1。
5.输入thread+ID切换调试线程
可以看到现在正在调试ID为1的主线程
6.其他相关调试命令
命令 | 用法 |
thread apply ID1 ID2....command | 让线程编号为1、2...的线程都执行command命令 |
thread apply all command | 让所有线程都执行command命令 |
set scheduler-locking on|off|set | 在调式某一个线程时,其他线程是否锁定 off:不锁定任何线程(默认为off) on:锁定其他线程,只有当前线程执行 step:单步时(step),只有被调试线程执行 |
set non-stop on|off | 在调试多线程程序时,这个选项默认为off,表示当一个线程停止时其他线程 全部停止。在该模式下,当一个线程停止时,其他线程可以继续运行。你可 以独立地对每个线程进行操作,在需要的时候停止或自由运行。 |
set pagination on|off | 在使用backtrace时,在分页时是否停止。 |
set target-async on|off | 同步和异步。同步,gdb在输出提示符之前等待程序报告一些线程已经终止 的信息。而异步的则是直接返回。 |