兩個線程,兩個互斥鎖如何形成死鎖?
程序流程圖如下:
程序流程圖
如上圖所示:
t0時刻,主線程創(chuàng)建子線程,并初始化互斥鎖mutex1、mutex2;
t1時刻,主線程申請到了mutex1、子線程申請到了mutex2;
t2時刻,主線程和子線程都sleep 1秒鐘,防止優(yōu)先獲得時間片的線程直接申請到了另外1個互斥鎖,導致程序直接退出;
t3時刻,主線程和子線程都想獲得對方手里的互斥鎖,但是對方都來不及釋放自己手里的鎖;
t4時刻,主線程和子線雙雙進入休眠。
【注意】為了保證主線程和子線程都能夠分別獲得鎖mutex1、mutex2,各自獲得鎖后一定要先sleep 1秒鐘,否則創(chuàng)建完子線程后,主線程還有一定的時間片,主線程會申請到鎖mutex2,無法形成死鎖。
死鎖
源碼如下
編譯運行
從執(zhí)行結(jié)果可以判斷,主線程和子線程分別獲得了互斥鎖mutex1、mutex2,sleep 1秒后,他們都想再分別申請mutex2、mutex1,而雙方都不想釋放自己手中的鎖,鎖已形成了死鎖,程序就一直處于休眠狀態(tài)。
查看下該進程的線程
查看進程ID,為4204
查看該進程創(chuàng)建的線程id:4204、4205。
責任編輯:xj
原文標題:兩個線程,兩個互斥鎖,怎么形成一個死循環(huán)?
文章出處:【微信公眾號:strongerHuang】歡迎添加關注!文章轉(zhuǎn)載請注明出處。
-
死鎖
+關注
關注
0文章
25瀏覽量
8079 -
線程
+關注
關注
0文章
505瀏覽量
19701
原文標題:兩個線程,兩個互斥鎖,怎么形成一個死循環(huán)?
文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關推薦
評論