首页
/
每日頭條
/
生活
/
死鎖真的存在嗎
死鎖真的存在嗎
更新时间:2025-12-01 16:25:20

《“死鎖”四個必要條件的合理解釋》分為三個部分:

【1】“死鎖”的含義

【2】“死鎖”的原因及四個必要條件的合理解釋

【3】“死鎖”的預防和解除

死鎖真的存在嗎(揭秘死鎖)1

1.“死鎖”的含義

所謂死鎖:是指兩個或兩個以上的進程在執行過程中,由于競争資源或者由于彼此通信而造成的一種阻塞的現象,若無外力作用,它們都将無法推進下去。此時稱系統處于死鎖狀态或系統産生了死鎖,這些永遠在互相等待的進程稱為死鎖進程。

2.“死鎖”産生的原因以及四個必要條件的合理解釋

産生死鎖的原因可歸結為如下兩點:

(1)競争資源。當系統中供多個進程共享的資源如打印機、公用隊列等,其數目不足以滿足進程的需要時,會引起諸進程的競争而産生死鎖。

(2)進程間推進順序非法。進程在運行過程中,請求和釋放資源的順序不當,也同樣會導緻産生進程死鎖。


産生死鎖的四個必要條件:

1.互斥(Mutual exclusion):存在這樣一種資源,它在某個時刻隻能被分配給一個執行緒(也稱為線程)使用;

2.持有(Hold and wait):當請求的資源已被占用從而導緻執行緒阻塞時,資源占用者不但無需釋放該資源,而且還可以繼續請求更多資源;

3.不可剝奪(No preemption):執行緒獲得到的互斥資源不可被強行剝奪,換句話說,隻有資源占用者自己才能釋放資源;

4.環形等待(Circular wait):若幹執行緒以不同的次序獲取互斥資源,從而形成環形等待的局面,想象在由多個執行緒組成的環形鍊中,每個執行緒都在等待下一個執行緒釋放它持有的資源。


發現到目前為止,所有的内容都可以在課本書籍、百度、論壇、博客上找到,似乎是教條的羅列。

我們發現看過多次,但每每需要的時候(開發、筆試、面試)卻總要回頭再看~難以擺脫遺忘、記憶的循環~我覺得産生這種現象的原因是因為:停留在機械記憶。

因為我們的教科書、論壇、博客的内容十有八九在羅列這些概念~但很少有進一步解釋、闡釋其存在的必然(四個必然條件為什麼不多一個,又為什麼不少一個?)及其内在邏輯。

或許下面的闡釋能讓你再遇到這個問題時,可以不翻教科書,不上網百度就能侃侃而談~

<1>.“死鎖”産生有幾個必要條件?

“死鎖”中“死”音通“四”是四個條件。(雖然很牽強,但對于識記,你會發現很有用!)

<2>.“四”鎖的必要條件都是指哪些?


1.資源互斥性(資源的屬性,不會同時屬于/分配給多個進程)->2.持有和等待(進程被分配(持有)資源後而且在等待(申請)其他資源)->3不可剝奪(對于已分配的資源,不可再強制收回來)->4.環形等待(進程之間資源等待形成相互依賴,互不禮讓)

用再通俗的話,進一步解釋這個逐漸升級的狀況。1->2->3->4是資源分配逐漸條件遞進、加強、升級的過程:資源是互斥的每次屬于一個進程(1.互斥);

資源分配了我占着而且我還要申請其他資源(2.持有和等待);

我占着的資源你沒法拿,你占着的資源我沒法拿(3.不可剝奪);

我申請的資源在你那,你申請的資源在我這(4.循環等待),最終形成了一個相互占有、相互等待的僵持局面~

3.“死鎖”的預防和解除

理解了死鎖的原因,尤其是産生死鎖的四個必要條件,就可以最大可能地避免、預防和解除死鎖,消除産生死鎖的四個必要條件中的任何一個都可以預防和解除死鎖。

不難看出,在死鎖的四個必要條件中,第二、三和四項條件比較容易消除。

1、靜态分配:采用資源靜态分配策略(進程資源靜态分配方式是指一個進程在建立時就分配了它需要的全部資源),破壞"部分分配"條件;

2、可剝奪:允許進程剝奪使用其他進程占有的資源,從而破壞"不可剝奪"條件;

3、有序分配:采用資源有序分配法,破壞"環路"條件。

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
玻璃碗可以微波爐加熱嗎
玻璃碗可以微波爐加熱嗎
玻璃碗可以微波爐加熱嗎?可以很多玻璃器皿都可以用來微波爐加熱,比如說微晶玻璃、氧化钛結晶玻璃、硼矽酸玻璃都可以,玻璃材質擁有穩定的物理化學性能,非常耐高溫,很适合在微波爐中長時間使用但是普通玻璃制作成的玻璃杯和牛奶瓶等隻适合在微波爐中加熱三...
2025-12-01
鴨蛋怎麼做湯沒有腥味
鴨蛋怎麼做湯沒有腥味
鴨蛋怎麼做湯沒有腥味?用料:鹹鴨蛋(熟)1個,青菜150克,色拉油15克,精鹽、味精、醬油、生姜各适量,下面我們就來聊聊關于鴨蛋怎麼做湯沒有腥味?接下來我們就一起去了解一下吧!鴨蛋怎麼做湯沒有腥味用料:鹹鴨蛋(熟)1個,青菜150克,色拉油...
2025-12-01
蘿蔔和姜能一起泡菜嗎
蘿蔔和姜能一起泡菜嗎
蘿蔔和姜能一起泡菜嗎?蘿蔔和生姜是可以一起做泡菜的白蘿蔔的功效還是很好的,幫助調節腸胃,很多人都知道白蘿蔔會有很好的作用,和生姜的搭配也是很不錯的,白蘿蔔含芥子油、澱粉酶和粗纖維,具有促進消化,增強食欲,加快胃腸蠕動和止咳化痰的功效姜有暖胃...
2025-12-01
菠蘿蜜幹自然風幹做法
菠蘿蜜幹自然風幹做法
菠蘿蜜幹自然風幹做法?食材:菠蘿蜜肉菠蘿蜜洗淨去核,撕成小條,今天小編就來聊一聊關于菠蘿蜜幹自然風幹做法?接下來我們就一起去研究一下吧!菠蘿蜜幹自然風幹做法食材:菠蘿蜜肉菠蘿蜜洗淨去核,撕成小條。在可以入微波爐的盤子上塗一層橄榄油,将菠蘿蜜...
2025-12-01
保衛蘿蔔3集市44關怎麼過
保衛蘿蔔3集市44關怎麼過
保衛蘿蔔3集市第43關是一個難度系數相對不高的關卡,此關共有20波怪物數,怪物等級為33級,屬于雙口通道的地圖。還是一起看看集市第43關怎麼過。保衛蘿蔔3集市第43關怎麼過?關卡簡介玩家在此關可利用的炮塔有七種,分别是瓶子炮、冰凍星、太陽花...
2025-12-01
Copyright 2023-2025 - www.tftnews.com All Rights Reserved