兩個線程,兩個互斥鎖如何形成死鎖?程序流程圖如下:

程序流程圖
如上圖所示:
t0時刻,主線程創(chuàng)建子線程,并初始化互斥鎖mutex1、mutex2;
t1時刻,主線程申請到了mutex1、子線程申請到了mutex2;
t2時刻,主線程和子線程都sleep 1秒鐘,防止優(yōu)先獲得時間片的線程直接申請到了另外1個互斥鎖,導(dǎo)致程序直接退出;
t3時刻,主線程和子線程都想獲得對方手里的互斥鎖,但是對方都來不及釋放自己手里的鎖;
t4時刻,主線程和子線雙雙進入休眠。
【注意】為了保證主線程和子線程都能夠分別獲得鎖mutex1、mutex2,各自獲得鎖后一定要先sleep 1秒鐘,否則創(chuàng)建完子線程后,主線程還有一定的時間片,主線程會申請到鎖mutex2,無法形成死鎖。
死鎖
源碼如下#include 《stdio.h》#include 《stdlib.h》#include 《string.h》#include 《pthread.h》 unsigned int value1, value2, count;pthread_mutex_t mutex1,mutex2;void *function(void *arg);void *function(void *arg){ pthread_mutex_lock(&mutex2); printf(“new thread get mutex2 ”); sleep(1); pthread_mutex_lock(&mutex1); printf(“new thread get mutex1 ”); pthread_mutex_unlock(&mutex1); printf(“new thread release mutex1 ”); pthread_mutex_unlock(&mutex2); printf(“new thread release mutex2 ”); return NULL; } int main(int argc, char *argv[]){ pthread_t a_thread; if (pthread_mutex_init(&mutex1, NULL) 《 0) { perror(“fail to mutex_init”); exit(-1); } if (pthread_mutex_init(&mutex2, NULL) 《 0) { perror(“fail to mutex_init”); exit(-1); } if (pthread_create(&a_thread, NULL, function, NULL) 《 0) { perror(“fail to pthread_create”); exit(-1); } while ( 1 ) { pthread_mutex_lock(&mutex1); printf(“main thread get mutex1 ”); sleep(1); pthread_mutex_lock(&mutex2); printf(“main thread get mutex2 ”); pthread_mutex_unlock(&mutex2); printf(“main thread release mutex2 ”); pthread_mutex_unlock(&mutex1); printf(“main thread release mutex1 ”); } return 0; }
編譯運行

從執(zhí)行結(jié)果可以判斷,主線程和子線程分別獲得了互斥鎖mutex1、mutex2,sleep 1秒后,他們都想再分別申請mutex2、mutex1,而雙方都不想釋放自己手中的鎖,鎖已形成了死鎖,程序就一直處于休眠狀態(tài)。
查看下該進程的線程查看進程ID,為4204

查看該進程創(chuàng)建的線程id:4204、4205。

責(zé)任編輯:haq
-
編程
+關(guān)注
關(guān)注
90文章
3707瀏覽量
96709 -
線程
+關(guān)注
關(guān)注
0文章
508瀏覽量
20748
發(fā)布評論請先 登錄
飛凌嵌入式ElfBoard-文件I/O的了解探究之競爭冒險
一個硬件SPI兩個CS操作兩個norflash,怎么互斥操作兩個norflash?
使用lv_label_set_text釋放內(nèi)存沒對齊是什么原因?qū)е碌模?/a>
rt-thread-master內(nèi)新修改dev_serial_v2.c后導(dǎo)致finsh線程循環(huán)無調(diào)度怎么解決?
官網(wǎng)nrf24l01的例程demo會出現(xiàn)互斥鎖報錯是為什么?
基本半導(dǎo)體連獲兩個行業(yè)獎項
看到STM8L152用兩個IO用兩個或非門檢測兩個通斷,是什么原理呢?
移植最新版的rt-thread nano時發(fā)現(xiàn)程序只要一進去entry函數(shù)就直接跳到一個死循環(huán)里,為什么?
stm32f103定時器2配置中斷,程序一直死循環(huán),無法進入中斷,怎么解決?
兩個不同頻率晶振靠的近會怎樣

兩個線程和互斥鎖如何形成死循環(huán)?
評論