




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、3.2 臨界區管理3.2.1 互斥與臨界區3.2.2 實現臨界區管理的幾種嘗試3.2.3 實現臨界區管理的軟件方法3.2.4 實現臨界區管理的硬件設施3.2.1互斥與臨界區(1)并發進程中與共享變量有關的程序段叫“臨界區”(Critical Section) , 共享變量代表的資源叫“臨界資源”(Critical Resource)。 與同一變量有關的臨界區分散在各進程的程序段中,而各進程的執行速度不可預知。如果保證進程在臨界區執行時,不讓另一個進程進入臨界區,即各進程對共享變量的訪問是互斥的,就不會造成與時間有關的錯誤。互斥與臨界區(2) 臨界區的調度原則:一次至多允許一個進程進入臨界區內一
2、個進程不能無限地停留在臨界區內一個進程不能無限地等待進入臨界區即-有空讓進、無空等待、 擇一而入、算法可行。臨界區管理的嘗試 (1)inside1,inside2:Booleaninside1 := false; /* P1不在其臨界區內 */inside2 := false; /* P2不在其臨界區內 */cobeginprocess P1 Beginwhile inside2 do begin end;inside1 := true;臨界區;inside1 := false; end;process P2 beginwhile inside1 do begin end;inside2 =
3、true;臨界區;inside2 := false; end;coendDekker算法(1) Dekker算法用一個指示器turn來指示應該哪一個進程進入臨界區。var inside : array1.2 of boolean;turn :integer;turn := 1 or 2; inside1:=false;inside2:=false; cobegin process P1begin inside1:=true;while inside2 do if turn=2 then begin inside1:=false; while turn=2 do begin end; insid
4、e1:=true; end臨界區;turn = 2; inside1:=false; end;Dekker算法(2) Peterson算法(1)var inside:array1.2 of boolean;turn:integer;turn := 1 or 2; inside1 := false;/* P1不在其臨界區內 */inside2 := false;/* P2不在其臨界區內 */Peterson算法(2)cobeginprocess P1 begininside1:= true;turn := 2;while (inside2 and turn=2) do begin end;臨界區
5、;inside1 := false; end;Peterson算法(3)process P2 begininside2 := true;turn := 1;while (inside1 and turn=1) do begin end;臨界區;inside2 := false; end;coend實現臨界區管理的硬件設施 關中斷 測試并建立指令 對換指令關中斷實現互斥的最簡單方法關中斷方法的缺點測試并建立指令(1) TS指令的處理過程 TS(x): 若x=true,則x:=false; return true;否則 return false; TS指令管理臨界區時,可把一個臨區與一個布爾變量s相連,由于變量s代表了臨界資源的狀態,可把它看成一把鎖。 對換指令(1) 對換(Swap)指令的功能是交換兩個字的內容: Swap (a,b): temp:=a; a:=b; b:=temp;對換指令(2)lock : boolean;lock := false;process Pi /* i = 1,2,n */ pi : bo
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- YY 0459-2025外科植入物丙烯酸類樹脂骨水泥
- 新疆北庭希望環保科技有限公司吉木薩爾縣25萬噸-年危廢處理利用項目(2)環評報告
- 某著名企業DeepSeek系列09DeepSeek政務應用場景與解決方案
- 工業廢水處理與綠色工藝技術
- 工業廢氣治理技術與方法探討
- 工業大數據的分析與應用
- 工業建筑設計及自動化機電系統
- 工業污染防治與綠色制造技術分析
- 工業網絡通信協議與技術標準
- 工業生產中的設備優化管理
- 項目重點難點分析及應對措施
- 24春國家開放大學《客戶關系管理》形考作業1-4參考答案
- 火焰原子吸收光譜法測定銅的含量結果分析
- 2024年煤礦電氣失爆專題培訓課件
- 《電機與電氣控制》期末考試復習題庫(含答案)
- MOOC 電子線路設計、測試與實驗(一)-華中科技大學 中國大學慕課答案
- 高速公路交通事故處理流程與責任認定
- 觀光電梯方案
- 盲人心理健康講座
- 混凝土箱涵技術規程
- 電力電子技術在電力系統中的應用
評論
0/150
提交評論