gdb除錯多執行緒出現的死鎖
阿新 • • 發佈:2018-11-19
多執行緒的條件下,程式很容易出現死鎖,此時各個執行緒處於等待狀態,可以通過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行,這樣就很順利的找到了死鎖出現的位置。