操作系統(tǒng)生產(chǎn)者消費(fèi)者問題代碼_第1頁
操作系統(tǒng)生產(chǎn)者消費(fèi)者問題代碼_第2頁
操作系統(tǒng)生產(chǎn)者消費(fèi)者問題代碼_第3頁
操作系統(tǒng)生產(chǎn)者消費(fèi)者問題代碼_第4頁
操作系統(tǒng)生產(chǎn)者消費(fèi)者問題代碼_第5頁
全文預(yù)覽已結(jié)束

下載本文檔

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

文檔簡介

1、#include #include #include #include #include /聲明所需變量int in=0;int out=0;HANDLE h_Thread20; /線程數(shù)組HANDLE empty_Semaphore; /表示空緩沖區(qū)的信號(hào)量HANDLE full_Semaphore; /表示空緩沖區(qū)的信號(hào)量HANDLE mutex; struct dataint ID;/序號(hào)char type;/類型,是生產(chǎn)者還是消費(fèi)者,p or cdouble delay;/線程延遲的時(shí)間,對應(yīng)生產(chǎn)者生產(chǎn)產(chǎn)品的時(shí)間或消費(fèi)者消費(fèi)產(chǎn)品的時(shí)間;data ThreadInfo20; /線程信息數(shù)

2、組 int length; /線程信息數(shù)組中實(shí)際的線程個(gè)數(shù)void Produce(void *p);/生產(chǎn)者進(jìn)程void Consume(void *p);/消費(fèi)者進(jìn)程void input(void);int main(void) input(); /初始化臨界區(qū)對象 /InitializeCriticalSection(&PC_Critical); empty_Semaphore=CreateSemaphore(NULL,10,10,NULL);full_Semaphore=CreateSemaphore(NULL,0,10,NULL);mutex = :CreateMutex(NULL,

3、FALSE,NULL);cout下面生產(chǎn)者和消費(fèi)者開始工作!endl;coutendl; /創(chuàng)建生產(chǎn)者和消費(fèi)者線程for(int i=0;ilength;i+)if(ThreadInfoi.type=p)h_Threadi=CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)(Produce),&(ThreadInfoi),0,NULL);else h_Threadi=CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)(Consume),&(ThreadInfoi),0,NULL); /主程序等待各個(gè)線程的動(dòng)作結(jié)束 Wa

4、itForMultipleObjects(length,h_Thread,TRUE,-1);coutendl;:Sleep();cout所有的生產(chǎn)者和消費(fèi)者都完成了它們的工作!endlID; my_delay=(data*)(p)-delay;/開始請求xiaofei cout消費(fèi)者my_id發(fā)出消費(fèi)請求。endl;coutendl; WaitForSingleObject(full_Semaphore,-1);:WaitForSingleObject(mutex,-1); /EnterCriticalSection(&PC_Critical);cout消費(fèi)者my_id消費(fèi).endl; out

5、=(out+1)%10;Sleep(my_delay*1000); cout消費(fèi)者my_id完成了消費(fèi)。endlendl; /LeaveCriticalSection(&PC_Critical); ReleaseSemaphore(empty_Semaphore,1,NULL);:ReleaseMutex(mutex); /*/輸入進(jìn)程信息的函數(shù)/*void input(void)/定義局部變量int id; char ch;double time; int k=0; cout* 請輸入線程信息: endl;cout* 線程ID; endl;cout* 線程的類型(生產(chǎn)者線程,還是消費(fèi)者線程,p代表生產(chǎn)者,c代表消費(fèi)者);endl;cout* 線程延遲時(shí)間。endl;cout* 線程ID為0時(shí)結(jié)束線程信息的輸入!endlendl;while(id!=0)coutplease input a thread ID.id;ThreadInfok.ID=id;if(id=0) break;coutplease input a thread type.ch;ThreadInfok.type=ch;coutplease input a thread delay time:time;ThreadInfok.delay=time;k+; length=k; coutendl您輸入的線程信息為 :

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(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ǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論