1. 程式人生 > >gdb除錯多執行緒出現的死鎖

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行,這樣就很順利的找到了死鎖出現的位置。