如何預(yù)防系統(tǒng)進(jìn)程死鎖具體該怎么操作
發(fā)布時(shí)間:2014-01-08 09:37:17 作者:佚名
我要評論

預(yù)防死鎖的根本辦法就是要使死鎖產(chǎn)生的4個(gè)必要條件之一不存在,那么如何破壞這些條件,下面為大家介紹下有哪些可能性
預(yù)防死鎖的根本辦法就是要使死鎖產(chǎn)生的4個(gè)必要條件之一不存在。下面來分析一下破壞這些條件的可能性。
破壞互斥條件
破壞互斥條件即允許多個(gè)進(jìn)程同時(shí)訪問資源。由于多數(shù)資源的必須互斥訪問這一固有特性不能改變,因此,死鎖的預(yù)防通過破壞這個(gè)必要條件實(shí)現(xiàn)在很多場合是行不通的。例如,打印機(jī)資源必須互斥使用,否則幾個(gè)進(jìn)程同時(shí)使用,每個(gè)進(jìn)程各打印一行,這種輸出信息的方式顯然是不能被用戶接受的。
破壞占有和等待條件
采用資源靜態(tài)分配法可破壞這一條件,該方法是指在進(jìn)程運(yùn)行前,一次性地_請分配它運(yùn)行所需的全部資源。若系統(tǒng)有足夠的資源分配給某一進(jìn)程,則一次性地將其所需資源分配給該進(jìn)程,這樣,在進(jìn)程運(yùn)行期間便不會(huì)再提出任何資源請求,從而使等待條件不成立。如果分配時(shí)有一種資源要求不能滿足,則進(jìn)程需要的其他資源也先不分配給進(jìn)程,從而避免進(jìn)程在等待期間占用任何資源,破壞了占用條件,從而避免死鎖的發(fā)生。
該方法控制簡單且容易實(shí)現(xiàn),但由于進(jìn)程運(yùn)行期間對所需資源的全部占用,使得某些使用時(shí)間很短的資源被長時(shí)間占用,這樣會(huì)嚴(yán)重影響系統(tǒng)資源的充分利用,導(dǎo)致資源利用率降低,同吋也影響到未獲得全部資源的進(jìn)程推遲運(yùn)行。
破壞不剝奪條件
采用剝奪式控制方法可以破壞該條件,該方法是使一個(gè)已保持了某些資源的進(jìn)程,由于新的資源要求目前得不到滿足,它必須先暫時(shí)釋放巳保持的所有資源(一種剝奪式),然后去等待,以后再一起向系統(tǒng)提出巾請,這樣也能防止死鎖。這種方法實(shí)現(xiàn)起來相對W難,為了保護(hù)進(jìn)程自動(dòng)放棄資源的現(xiàn)場以及后來的再次恢復(fù),需要付出高昂的代價(jià),并且這種方法只適用于處理機(jī)和存儲器資源,對其他資源,此法不宜使用。
破壞循環(huán)等待條件
采用資源順序分配法可破壞該條件。這種分配方法的基本思想是:把系統(tǒng)的全部資源分成多個(gè)層次,一個(gè)進(jìn)程得到某一層的一個(gè)資源后,它只能再_請較高一層的資源;當(dāng)一個(gè)進(jìn)程要釋放某層的一個(gè)資源時(shí),必須先釋放所占有的較高層的資源;當(dāng)一個(gè)進(jìn)程獲得了某一層的一個(gè)資源后,它想再申請?jiān)搶又械牧硪粋€(gè)資源,就必須先釋放在該層中巳占有的資源?;蛘哒f,進(jìn)程釋放資源的順序是按照中請資源的相反順序進(jìn)行的。這樣可以預(yù)防循環(huán)等待現(xiàn)象的發(fā)生,因此不會(huì)發(fā)生死鎖。使用該方法要特別注意的問題是對資源所處層次的安排。在通常情況下,把各進(jìn)程經(jīng)常用到的、比較普遍的資源安排在較低的層次上,把重要且相對匱乏的資源安排在較高的層次上,以便實(shí)現(xiàn)對各資源的最大限度的利用。該方法相對于前面介紹的方法,在資源利用率和系統(tǒng)吞吐量上都有明顯的改善。但也存在一些缺陷。
(1)低層次的資源必須在進(jìn)程請求分配髙層次的資源之前提前申請,這對于暫時(shí)不需使用的低層次資源來說,會(huì)因空閑等待而產(chǎn)生浪費(fèi)。
(2)各類設(shè)備的資源層次一經(jīng)設(shè)定,便不能經(jīng)常隨意改動(dòng),這就限制了新類型設(shè)備的增加。
(3)各資源的層次是按照大多數(shù)進(jìn)程使用資源的順序設(shè)置的。對于資源使用與此層次相閃配的進(jìn)程,資源能得到有效的利用,否則,資源的浪費(fèi)現(xiàn)象將仍然存在。
破壞互斥條件
破壞互斥條件即允許多個(gè)進(jìn)程同時(shí)訪問資源。由于多數(shù)資源的必須互斥訪問這一固有特性不能改變,因此,死鎖的預(yù)防通過破壞這個(gè)必要條件實(shí)現(xiàn)在很多場合是行不通的。例如,打印機(jī)資源必須互斥使用,否則幾個(gè)進(jìn)程同時(shí)使用,每個(gè)進(jìn)程各打印一行,這種輸出信息的方式顯然是不能被用戶接受的。
破壞占有和等待條件
采用資源靜態(tài)分配法可破壞這一條件,該方法是指在進(jìn)程運(yùn)行前,一次性地_請分配它運(yùn)行所需的全部資源。若系統(tǒng)有足夠的資源分配給某一進(jìn)程,則一次性地將其所需資源分配給該進(jìn)程,這樣,在進(jìn)程運(yùn)行期間便不會(huì)再提出任何資源請求,從而使等待條件不成立。如果分配時(shí)有一種資源要求不能滿足,則進(jìn)程需要的其他資源也先不分配給進(jìn)程,從而避免進(jìn)程在等待期間占用任何資源,破壞了占用條件,從而避免死鎖的發(fā)生。
該方法控制簡單且容易實(shí)現(xiàn),但由于進(jìn)程運(yùn)行期間對所需資源的全部占用,使得某些使用時(shí)間很短的資源被長時(shí)間占用,這樣會(huì)嚴(yán)重影響系統(tǒng)資源的充分利用,導(dǎo)致資源利用率降低,同吋也影響到未獲得全部資源的進(jìn)程推遲運(yùn)行。
破壞不剝奪條件
采用剝奪式控制方法可以破壞該條件,該方法是使一個(gè)已保持了某些資源的進(jìn)程,由于新的資源要求目前得不到滿足,它必須先暫時(shí)釋放巳保持的所有資源(一種剝奪式),然后去等待,以后再一起向系統(tǒng)提出巾請,這樣也能防止死鎖。這種方法實(shí)現(xiàn)起來相對W難,為了保護(hù)進(jìn)程自動(dòng)放棄資源的現(xiàn)場以及后來的再次恢復(fù),需要付出高昂的代價(jià),并且這種方法只適用于處理機(jī)和存儲器資源,對其他資源,此法不宜使用。
破壞循環(huán)等待條件
采用資源順序分配法可破壞該條件。這種分配方法的基本思想是:把系統(tǒng)的全部資源分成多個(gè)層次,一個(gè)進(jìn)程得到某一層的一個(gè)資源后,它只能再_請較高一層的資源;當(dāng)一個(gè)進(jìn)程要釋放某層的一個(gè)資源時(shí),必須先釋放所占有的較高層的資源;當(dāng)一個(gè)進(jìn)程獲得了某一層的一個(gè)資源后,它想再申請?jiān)搶又械牧硪粋€(gè)資源,就必須先釋放在該層中巳占有的資源?;蛘哒f,進(jìn)程釋放資源的順序是按照中請資源的相反順序進(jìn)行的。這樣可以預(yù)防循環(huán)等待現(xiàn)象的發(fā)生,因此不會(huì)發(fā)生死鎖。使用該方法要特別注意的問題是對資源所處層次的安排。在通常情況下,把各進(jìn)程經(jīng)常用到的、比較普遍的資源安排在較低的層次上,把重要且相對匱乏的資源安排在較高的層次上,以便實(shí)現(xiàn)對各資源的最大限度的利用。該方法相對于前面介紹的方法,在資源利用率和系統(tǒng)吞吐量上都有明顯的改善。但也存在一些缺陷。
(1)低層次的資源必須在進(jìn)程請求分配髙層次的資源之前提前申請,這對于暫時(shí)不需使用的低層次資源來說,會(huì)因空閑等待而產(chǎn)生浪費(fèi)。
(2)各類設(shè)備的資源層次一經(jīng)設(shè)定,便不能經(jīng)常隨意改動(dòng),這就限制了新類型設(shè)備的增加。
(3)各資源的層次是按照大多數(shù)進(jìn)程使用資源的順序設(shè)置的。對于資源使用與此層次相閃配的進(jìn)程,資源能得到有效的利用,否則,資源的浪費(fèi)現(xiàn)象將仍然存在。
相關(guān)文章
如何把操作系統(tǒng)遷移到新硬盤里 操作系統(tǒng)遷移到新硬盤
為了保證遷移之后可以順利從新盤啟動(dòng),操作系統(tǒng)如何順利遷移到新硬盤呢?下面小編給大家?guī)砹瞬僮飨到y(tǒng)遷移到新硬盤的方法,感興趣的朋友跟隨小編一起看看吧2023-04-21WmiPrvSE.exe是什么進(jìn)程?WMI Provider Host占用很高CPU的解決方法
很多用戶在操作Win10系統(tǒng)的過程中,會(huì)發(fā)現(xiàn)WmiPrvSE.exe進(jìn)程,但是占用CPU很高,怎么辦呢?下文就為大家?guī)砹嗽敿?xì)的解決方法,一起看看吧2023-01-14dllhost.exe進(jìn)程占用CPU很高怎么解決?全面解析dllhost.exe進(jìn)程
這篇文章主要介紹了dllhost.exe進(jìn)程占用CPU很高怎么解決?全面解析dllhost.exe進(jìn)程的相關(guān)資料,需要的朋友可以參考下本文詳細(xì)內(nèi)容介紹2022-05-27啟動(dòng)Autodesk Desktop Licensing Service時(shí)出現(xiàn)錯(cuò)誤1067:進(jìn)程意外終止
許多用戶在啟動(dòng)Autodesk Desktop Licensing Service時(shí),經(jīng)常會(huì)出現(xiàn)Windows無法在本地計(jì)算機(jī)上啟動(dòng)Autodesk Desktop Licensing Service服務(wù)錯(cuò)誤1067,下文就為大家?guī)砹嗽?/div> 2021-08-23fxksmdb.exe 是什么進(jìn)程 fxksmdb.exe可以關(guān)閉嗎
今天打開電腦應(yīng)用進(jìn)程發(fā)現(xiàn)fxksmdb.exe、fxksmpl.exe、fxksmW.exe三個(gè)進(jìn)程,經(jīng)過查看文件路徑發(fā)現(xiàn)原來是施樂打印機(jī)的驅(qū)動(dòng)程序自帶的應(yīng)用,平時(shí)都沒注意到這個(gè),這下放心了2018-11-11keyiso是什么進(jìn)程 服務(wù)中的Keyiso服務(wù)器是否是病毒
今天在服務(wù)器中看到Keyiso進(jìn)程,看字面意思Keyiso就是CNG Key Isolation系統(tǒng)服務(wù),如果無法啟用會(huì)導(dǎo)致依賴的無線服務(wù)沒辦法啟動(dòng),現(xiàn)在無線網(wǎng)絡(luò)沒辦法用,所以這個(gè)是有用的2018-05-04TaobaoProtect.exe進(jìn)程怎么刪除? 結(jié)束TaobaoProtect.exe的教程
TaobaoProtect.exe進(jìn)程怎么刪?電腦中有TaobaoProtect.exe進(jìn)程占用內(nèi)存,想要結(jié)束這個(gè)進(jìn)程,該怎么結(jié)束呢?下面我們就來看看結(jié)束TaobaoProtect.exe的教程,需要的朋友可以2017-08-11qttask.exe是什么進(jìn)程?qttask.exe是不是病毒?
部分網(wǎng)友朋友問小編qttask.exe是什么進(jìn)程?qttask.exe是不是病毒?qttask.exe占內(nèi)存大可以關(guān)閉嗎?小編上網(wǎng)查詢整理了關(guān)于qttask.exe相關(guān)內(nèi)容,不清楚的朋友可以認(rèn)真查看本2017-07-25qqprotect.exe是什么進(jìn)程?qqprotect.exe怎么禁止自動(dòng)啟動(dòng)?
最近,有網(wǎng)友問小編qqprotect.exe是什么進(jìn)程?qqprotect.exe怎么禁止自動(dòng)啟動(dòng)?qqprotect.exe應(yīng)用程序錯(cuò)誤怎么辦?小編通過整理分享了qqprotect.exe相關(guān)內(nèi)容的介紹以及qqpr2017-07-19TpKmpSVC.exe是什么進(jìn)程?TpKmpSVC.exe是病毒嗎?
有部分網(wǎng)友朋友問小編 tpkmpsvc.exe是什么進(jìn)程?tpkmpsvc.exe 是病毒?tpkmpsvc.exe可以關(guān)閉嗎?小編根據(jù)大家的疑問整理來tpkmpsvc.exe相關(guān)內(nèi)容的詳細(xì)介紹,有疑惑的朋友快來2017-07-18最新評論