首頁 >常見問題 >系統出現死鎖的原因

系統出現死鎖的原因

(*-*)浩
(*-*)浩原創
2019-10-23 10:23:3840391瀏覽

若干進程因競爭資源而無止盡地等待其他進程釋放已佔有的資源。

系統出現死鎖的原因

電腦系統中有限的資源與眾多請求分配資源的進程間存在矛盾。當若干進程需求資源的總數大於系統所能提供的資源數時,進程間就會出現搶佔資源的現象,如果對進程搶佔的資源管理或分配不當就會造成死鎖。  (推薦學習:web前端視訊教學

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

產生條件

雖然進程在運作過程中,可能發生死鎖,但死鎖的發生也必須具備一定的條件,死鎖的發生必須具備以下四個必要條件。

1)互斥條件:指進程對所指派的資源進行排它性使用,即在一段時間內某資源只由一個程序佔用。如果此時還有其它進程請求資源,則請求者只能等待,直至佔有資源的程序用畢釋放。

2)請求與保持條件:指進程已經保持至少一個資源,但又提出了新的資源請求,而該資源已被其它進程佔有,此時請求進程阻塞,但又對自己已獲得的其它資源保持不放。

3)不剝奪條件:指進程已獲得的資源,在未使用完之前,不能被剝奪,只能在使用完時由自己釋放。

4)環路等待條件:指在發生死鎖時,必然存在一個進程-資源的環形鏈,即進程集合{P0,P1,P2,···,Pn}中的P0正在等待一個P1佔用的資源;P1正在等待P2佔用的資源,…,Pn正在等待已被P0佔用的資源。

產生原因

競爭資源造成進程死鎖

當系統中供多個行程共享的資源如印表機、公用佇列的等,其數目不足以滿足諸進程的需要時,會引起諸進程對資源的競爭而產生死鎖。

競賽臨時資源

上面所說的印表機資源屬於可依序重複使用型資源,稱為永久資源。還有一種所謂的臨時資源,這是指由一個行程產生,被另一個行程使用,短時間後便無用的資源,故也稱為消耗性資源,如硬體中斷、訊號、訊息、緩衝區內的訊息等,它也可能引起死鎖。

以上是系統出現死鎖的原因的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn