gdb调试多线程出现的死锁

   多线程的条件下,程序很容易出现死锁,此时各个线程处于等待状态,可以通过gdb调试找到死锁出现的地方。


例子:

#include <stdio.h>

#include <pthread.h>
#include <unistd.h>

pthread_mutex_t lockA = PTHREAD_MUTEX_INITIALIZER;
pthread_mutex_t lockB = PTHREAD_MUTEX_INITIALIZER;

void *thread_A(void *arg) {
(void)arg;

pthread_t tid = pthread_self();

printf("%lu : Acquire lockA...\n", tid);
pthread_mutex_lock(&lockA);
printf("%lu : lockA acquired, Acquire lockB...\n", tid);
pthread_mutex_lock(&lockB);
printf("%lu : lockB acquired\n", tid);

printf("Exit thread_A...\n");

pthread_mutex_unlock(&lockB);
pthread_mutex_unlock(&lockA);

return 0;
}

void *thread_B(void *arg) {
(void)arg;

pthread_t tid = pthread_self();

printf("%lu : Acquire lockB...\n", tid);
pthread_mutex_lock(&lockB);
printf("%lu : lockB acquired, Acquire lockA...\n", tid);
pthread_mutex_lock(&lockA);
printf("%lu : lockA acquired\n", tid);

printf("Exit thread_B...\n");

pthread_mutex_unlock(&lockA);
pthread_mutex_unlock(&lockB);

return 0;
}

int main(int argc, char *argv[])
{
(void)argc;
(void)argv;

pthread_t pA;
pthread_t pB;

pthread_create(&pA, 0, thread_A, 0);
pthread_create(&pB, 0, thread_B, 0);

pthread_join(pA, 0);
pthread_join(pB, 0);

printf("quit...\n");

return 0;
}


编译:gcc  -g -o deadlock deadlock.c -lpthread


运行可执行文件,直到出现死锁情况。


如下命令进行调试:

1. ps aux | grep deadlock:找到该进程号

2. gdb deadlock PID: 进入进程调试

3. generate-core-file:查看线程前,保存core文件

4. info threads: 查看所有线程

5. thread 2: 选择进入第二个线程

6. bt: 查看该线程调用的堆栈信息


可以看到出现死锁的位置在源文件的35行,这样就很顺利的找到了死锁出现的位置。


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值