復(fù)試操作系統(tǒng)ch3_第1頁
復(fù)試操作系統(tǒng)ch3_第2頁
復(fù)試操作系統(tǒng)ch3_第3頁
復(fù)試操作系統(tǒng)ch3_第4頁
復(fù)試操作系統(tǒng)ch3_第5頁
已閱讀5頁,還剩4頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、計(jì)算機(jī)操作系統(tǒng)陳勃 生產(chǎn)者/消費(fèi)者問題生產(chǎn)者消費(fèi)者倉庫用兩個(gè)進(jìn)程Pro和Con分別表示生產(chǎn)者和消費(fèi)者,用數(shù)組B表示最大庫存為k的倉庫,Pro和Con的(無進(jìn)程同步)代碼為Pro() 生產(chǎn)貨物; 查找B中任意空位in; 將貨物放入Bin;Con() 查找B中任意存有貨物的位置out; 取出貨物Bout; 消費(fèi)貨物;生產(chǎn)者/消費(fèi)者問題Pro() 生產(chǎn)貨物; 查找B中任意空位in; 將貨物放入Bin;Con() 查找B中任意存有貨物的位置out; 取出貨物Bout; 消費(fèi)貨物;v(item);v(slot);p(item);p(slot);信號(hào)量初始化:item = 0; slot = k;(正信號(hào)

2、量可表示就緒資源的數(shù)量)生產(chǎn)者/消費(fèi)者問題Pro() 生產(chǎn)貨物;top+;將貨物放入Btop;Con() 取出貨物Btop;top-;消費(fèi)貨物;若規(guī)定倉庫必須保持“棧式使用”方式 ,top表示最上方的貨物在倉庫中的位置(棧頂?shù)刂罚?,初始化top = -1p(slot);v(item);v(slot);p(item);p(mutex);p(mutex);v(mutex);v(mutex);當(dāng)連續(xù)使用原語p時(shí),控制互斥關(guān)系的原語p應(yīng)當(dāng)置于內(nèi)層。生產(chǎn)者/消費(fèi)者問題Pro() 生產(chǎn)貨物;查找B中任意空位in;將貨物放入Bin;Con() 查找B中任意存有貨物的位置out; 取出貨物Bout; 消費(fèi)貨物

3、;v(item);v(slot);p(item);p(slot);p(mutexIn);v(mutexIn);p(mutexOut);v(mutexOut);若系統(tǒng)中同時(shí)存在多個(gè)生產(chǎn)者與多個(gè)消費(fèi)者,則原先的程序:需要考慮生產(chǎn)者間和消費(fèi)者間的互斥關(guān)系。讀者/寫者問題寫者讀者用一個(gè)進(jìn)程Writer表示寫者,用多個(gè)進(jìn)程Reader表示讀者,Writer和Reader的代碼為Writer() 寫操作段;Reader() 讀操作段;讀者讀者p(mutexWR);p(mutexWR);v(mutexWR);v(mutexWR);導(dǎo)致各reader間互斥讀者/寫者問題僅在第一個(gè)reader開始時(shí)對(duì)mutex

4、WR做p操作,最后一個(gè)reader結(jié)束時(shí)對(duì)mutexWR做v操作,而在其他reader運(yùn)行中不改動(dòng)信號(hào)量,改進(jìn)的代碼:Writer() p(mutexWR); 寫操作段; v(mutexWR);Reader() readerCount+; if(readerCount=1) p(mutexWR); 讀操作段; readerCount-; if(readerCount=0) v(mutexWR);p(mutexRC);v(mutexRC);p(mutexRC);v(mutexRC);復(fù)雜的同步關(guān)系L1L3p(s2)L2andp(s1)v(s2)v(s1)L1L3p(s)L2orv(s)v(s)多個(gè)前序步驟與單個(gè)后續(xù)步驟的同步關(guān)系:復(fù)雜的同步關(guān)系L1L0L2excludedp(

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論