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

評(píng)論