国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 課堂 > DLL進程 > 正文

如何預防系統(tǒng)進程死鎖具體該怎么操作

2020-06-18 12:56:52
字體:
供稿:網(wǎng)友
預防死鎖的根本辦法就是要使死鎖產(chǎn)生的4個必要條件之一不存在,那么如何破壞這些條件,下面為大家介紹下有哪些可能性

預防死鎖的根本辦法就是要使死鎖產(chǎn)生的4個必要條件之一不存在。下面來分析一下破壞這些條件的可能性。

破壞互斥條件

破壞互斥條件即允許多個進程同時訪問資源。由于多數(shù)資源的必須互斥訪問這一固有特性不能改變,因此,死鎖的預防通過破壞這個必要條件實現(xiàn)在很多場合是行不通的。例如,打印機資源必須互斥使用,否則幾個進程同時使用,每個進程各打印一行,這種輸出信息的方式顯然是不能被用戶接受的。

破壞占有和等待條件

采用資源靜態(tài)分配法可破壞這一條件,該方法是指在進程運行前,一次性地_請分配它運行所需的全部資源。若系統(tǒng)有足夠的資源分配給某一進程,則一次性地將其所需資源分配給該進程,這樣,在進程運行期間便不會再提出任何資源請求,從而使等待條件不成立。如果分配時有一種資源要求不能滿足,則進程需要的其他資源也先不分配給進程,從而避免進程在等待期間占用任何資源,破壞了占用條件,從而避免死鎖的發(fā)生。

該方法控制簡單且容易實現(xiàn),但由于進程運行期間對所需資源的全部占用,使得某些使用時間很短的資源被長時間占用,這樣會嚴重影響系統(tǒng)資源的充分利用,導致資源利用率降低,同吋也影響到未獲得全部資源的進程推遲運行。

破壞不剝奪條件

采用剝奪式控制方法可以破壞該條件,該方法是使一個已保持了某些資源的進程,由于新的資源要求目前得不到滿足,它必須先暫時釋放巳保持的所有資源(一種剝奪式),然后去等待,以后再一起向系統(tǒng)提出巾請,這樣也能防止死鎖。這種方法實現(xiàn)起來相對W難,為了保護進程自動放棄資源的現(xiàn)場以及后來的再次恢復,需要付出高昂的代價,并且這種方法只適用于處理機和存儲器資源,對其他資源,此法不宜使用。

破壞循環(huán)等待條件

采用資源順序分配法可破壞該條件。這種分配方法的基本思想是:把系統(tǒng)的全部資源分成多個層次,一個進程得到某一層的一個資源后,它只能再_請較高一層的資源;當一個進程要釋放某層的一個資源時,必須先釋放所占有的較高層的資源;當一個進程獲得了某一層的一個資源后,它想再申請該層中的另一個資源,就必須先釋放在該層中巳占有的資源。或者說,進程釋放資源的順序是按照中請資源的相反順序進行的。這樣可以預防循環(huán)等待現(xiàn)象的發(fā)生,因此不會發(fā)生死鎖。使用該方法要特別注意的問題是對資源所處層次的安排。在通常情況下,把各進程經(jīng)常用到的、比較普遍的資源安排在較低的層次上,把重要且相對匱乏的資源安排在較高的層次上,以便實現(xiàn)對各資源的最大限度的利用。該方法相對于前面介紹的方法,在資源利用率和系統(tǒng)吞吐量上都有明顯的改善。但也存在一些缺陷。

(1)低層次的資源必須在進程請求分配髙層次的資源之前提前申請,這對于暫時不需使用的低層次資源來說,會因空閑等待而產(chǎn)生浪費。

(2)各類設備的資源層次一經(jīng)設定,便不能經(jīng)常隨意改動,這就限制了新類型設備的增加。

(3)各資源的層次是按照大多數(shù)進程使用資源的順序設置的。對于資源使用與此層次相閃配的進程,資源能得到有效的利用,否則,資源的浪費現(xiàn)象將仍然存在。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 长子县| 讷河市| 新丰县| 昂仁县| 衡阳市| 类乌齐县| 文成县| 西华县| 保亭| 陇西县| 林州市| 股票| 新密市| 府谷县| 平定县| 区。| 白城市| 乌兰浩特市| 迭部县| 焉耆| 西乌珠穆沁旗| 高邑县| 津南区| 广汉市| 治县。| 通化市| 广昌县| 疏勒县| 澄城县| 福安市| 定结县| 长葛市| 武宣县| 岳普湖县| 沽源县| 当雄县| 陆丰市| 韶山市| 雷山县| 布拖县| 星子县|