




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、 長春理工大學(xué)大學(xué)學(xué)生實(shí)驗(yàn)報告書學(xué)生用表 實(shí)驗(yàn)名稱 緩沖池的模擬實(shí)現(xiàn)課程名稱 操作系統(tǒng) 課程號 學(xué)院(系) 軟件學(xué)院 專業(yè) 軟件工程 班級 學(xué)生姓名 學(xué)號 實(shí)驗(yàn)地點(diǎn) 實(shí)驗(yàn)日期 一、實(shí)驗(yàn)?zāi)康?1掌握緩沖池的結(jié)構(gòu) 2掌握緩沖池的使用方法 二、實(shí)驗(yàn)內(nèi)容 1、實(shí)現(xiàn)輸入、計(jì)算、輸出進(jìn)程并發(fā)執(zhí)行 2、實(shí)現(xiàn)getBuf和putBuf函數(shù)。 三、實(shí)驗(yàn)步驟 1、整體設(shè)計(jì)包括三個線程的模擬設(shè)計(jì)三個隊(duì)列的鏈表設(shè)計(jì)還有三個隊(duì)列的同步與互斥的設(shè)計(jì)等 2、由于本次實(shí)驗(yàn)沒有需要太多的數(shù)據(jù)結(jié)構(gòu)因此數(shù)據(jù)結(jié)構(gòu)的設(shè)計(jì)就只有三個緩沖隊(duì)列的設(shè)計(jì)先構(gòu)造一個空的緩沖隊(duì)列該隊(duì)列是一個實(shí)體即是一個確定的有結(jié)點(diǎn)的鏈表它是模擬緩沖池的載體輸入與輸
2、出隊(duì)列在構(gòu)造時只有它的頭尾指針而沒有它的實(shí)體這是因?yàn)樗梢詮目站彌_區(qū)里獲得例如當(dāng)計(jì)算線程要數(shù)據(jù)計(jì)算時便可從空隊(duì)列里獲取一個緩沖區(qū)作為輸入緩沖使用再把它掛載到輸入隊(duì)列的隊(duì)尾中去 算法流程圖 實(shí)驗(yàn)內(nèi)容如下 /緩沖隊(duì)列類型的定義 #define EMQ 0 /空緩沖隊(duì)列 #define INQ 1 /輸入緩沖隊(duì)列 #define OUTQ 2 /輸出緩沖隊(duì)列 const int bufferpoolsize = 50; /緩沖池大小,默認(rèn)設(shè)置為50個 /結(jié)束運(yùn)行標(biāo)志 short int m_end ; GDOU-B-11-112 /緩沖結(jié)構(gòu)體的定義 typedef struct Buffer int
3、 BufNo; /緩沖區(qū)號 int buf; /緩沖內(nèi)容 Buffer *next; /緩沖指向下一個指針 buffer; /線程函數(shù)聲明 DWORD WINAPI InputThreadFunc(LPVOID lpPara); /輸入線程函數(shù) DWORD WINAPI OutputThreadFunc(LPVOID lpPara); /輸出線程函數(shù) DWORD WINAPI CalThreadFunc(LPVOID lpPara); /計(jì)算線程函數(shù) /加入與摘取隊(duì)列函數(shù)聲明 void putBuf(int type , buffer *buf); /掛載到隊(duì)列尾 buffer* getBuf
4、(int type); /從隊(duì)列頭中摘取一個緩沖區(qū) /構(gòu)造緩沖池函數(shù)的聲明 void ConstructBuffer(); /線程的句柄 HANDLE hInputT; /輸入線程 HANDLE hOutputT; /輸出線程 HANDLE hCalculateT; /計(jì)算線程 /線程的ID DWORD InputTid; /輸入線程 DWORD OutputTid; /輸出線程 DWORD CalculateTid; /計(jì)算線程 /三個互斥量信號句柄 HANDLE hmutexEMQ; /空隊(duì)列的互斥信號量 HANDLE hmutexOUTQ; /裝滿輸出隊(duì)列的互斥信號量 HANDLE hm
5、utexINQ; /裝滿輸入隊(duì)列的互斥信號量 /三個同步信號量 HANDLE hsemINQ; HANDLE hsemOUTQ; HANDLE hsemEMQ; #include windows.h #include iostream #include stdlib.h #include time.h #include Main1.h using namespace std; /三個緩沖隊(duì)列頭與尾指針 buffer *hemq , *hinq , *houtq; /隊(duì)頭指針 buffer *lemq , *linq , *loutq; /隊(duì)尾指針 /主函數(shù) int main() coutsho
6、w1endlshow2endlshow3endlendl; m_end = 1 ; /運(yùn)行結(jié)束標(biāo)志 ConstructBuffer(); /構(gòu)造緩沖池 /創(chuàng)建互斥對象 hmutexEMQ = CreateMutex(NULL,FALSE,NULL); hmutexOUTQ = CreateMutex(NULL,FALSE,NULL); hmutexINQ = CreateMutex(NULL,FALSE,NULL); /創(chuàng)建信號量對象 hsemINQ = CreateSemaphore(NULL,0,bufferpoolsize,NULL); hsemOUTQ = CreateSemaphor
7、e(NULL,0,bufferpoolsize,NULL); hsemEMQ = CreateSemaphore(NULL,bufferpoolsize,bufferpoolsize,NULL); /創(chuàng)建線程 hInputT = CreateThread(NULL,0,InputThreadFunc,NULL,0,&InputTid); Sleep(10); hCalculateT = CreateThread(NULL,0,CalThreadFunc,NULL,0,&CalculateTid); Sleep(10); hOutputT = CreateThread(NULL,0,Output
8、ThreadFunc,NULL,0,&OutputTid); /Sleep(10000); /system(pause); if(getchar() /按回車后終止程序運(yùn)行 m_end = 0 ; cout程序已經(jīng)終止!buf = nRandom ; cout輸入線程從 緩沖單元 BufNodata= bufendl; ReleaseMutex(hmutexEMQ); /釋放互斥對象信號 /控制訪問輸入隊(duì)列的互斥量 WaitForSingleObject(hmutexINQ,INFINITE); putBuf(INQ,getbuf) ; /將輸入的緩沖區(qū)掛載到輸入隊(duì)列的隊(duì)尾 ReleaseMu
9、tex(hmutexINQ); ReleaseSemaphore(hsemINQ,1,NULL); return 0; /輸出線程函數(shù)的實(shí)現(xiàn) DWORD WINAPI OutputThreadFunc(LPVOID lpPara) /輸出線程函數(shù) buffer* Outputbuf ; /一個臨時交換區(qū) while(m_end) Sleep(100); /同步與互斥的控制 WaitForSingleObject(hsemOUTQ,INFINITE); WaitForSingleObject(hmutexOUTQ,INFINITE); Outputbuf = getBuf(OUTQ) ; /從輸
10、出隊(duì)列中提取一個提取輸出緩沖區(qū) cout輸出線程從 緩沖單元 BufNodata= bufbuf = -1 ; /提取完成后將該緩沖區(qū)回收 ReleaseMutex(hmutexOUTQ); WaitForSingleObject(hmutexEMQ,INFINITE); putBuf(EMQ,Outputbuf) ; /回收的把它掛載到空隊(duì)列的隊(duì)尾 ReleaseMutex(hmutexEMQ); ReleaseSemaphore(hsemEMQ,1,NULL); return 0; /計(jì)算線程函數(shù)的實(shí)現(xiàn) DWORD WINAPI CalThreadFunc(LPVOID lpPara) /
11、計(jì)算線程函數(shù) buffer* Calbuf1 = NULL; buffer* Calbuf2 =NULL; int nCal; while(m_end) Sleep(10); /因?yàn)橛?jì)算線程的速度遠(yuǎn)遠(yuǎn)快于輸入與輸出線程所以它的休眠時間應(yīng)很小 /同步與互斥的控制 WaitForSingleObject(hsemINQ,INFINITE); WaitForSingleObject(hmutexINQ,INFINITE); Calbuf1 = getBuf(INQ); /從輸入隊(duì)列中提取一個收容輸入緩沖區(qū) nCal = Calbuf1-buf; /提取數(shù)據(jù) cout計(jì)算線程從 緩沖單元 BufNod
12、ata= bufbuf = -1 ; /系統(tǒng)將收回此緩沖區(qū)表示該緩沖區(qū)已空 ReleaseMutex(hmutexINQ); WaitForSingleObject(hmutexEMQ,INFINITE); putBuf(EMQ,Calbuf1); ReleaseMutex(hmutexEMQ); ReleaseSemaphore(hsemEMQ,1,NULL); nCal = nCal + 10000 ; /模擬輸入數(shù)據(jù)的處理 WaitForSingleObject(hsemEMQ,INFINITE); WaitForSingleObject(hmutexEMQ,INFINITE); Cal
13、buf2 = getBuf(EMQ); /得到一個空的緩沖區(qū)作為收容輸出 Calbuf2-buf = nCal ; /存入運(yùn)算結(jié)果 cout計(jì)算線程從 緩沖單元 BufNodata= bufnext-next != NULL) Returnbuf = hemq-next ; /取得隊(duì)列頭 hemq-next = Returnbuf-next; /修正隊(duì)列鏈表頭指針的指向 Returnbuf-next = NULL; return Returnbuf; else /假如該緩沖隊(duì)列的個數(shù)只有一個的話則使得隊(duì)頭指針與隊(duì)尾指針相等級 /這樣的話就可以防止隊(duì)尾指針的丟失 Returnbuf = hemq
14、-next ; hemq-next = Returnbuf-next; Returnbuf-next = NULL; lemq = hemq ; return Returnbuf; break; case 1: if(hinq != linq & hinq-next-next != NULL) Returnbuf = hinq-next; hinq-next = Returnbuf-next; Returnbuf-next =NULL; return Returnbuf; else Returnbuf = hinq-next ; hinq-next = Returnbuf-next; Retu
15、rnbuf-next = NULL; linq = hinq; return Returnbuf; break; case 2: if(houtq != loutq & houtq-next-next !=NULL ) Returnbuf = houtq-next ; houtq-next = Returnbuf-next; Returnbuf-next = NULL; return Returnbuf; else Returnbuf = houtq-next; houtq-next = Returnbuf-next ; Returnbuf-next = NULL; loutq = houtq
16、; return Returnbuf; break; /把某一類型的緩沖區(qū)掛載到隊(duì)尾函數(shù) /(實(shí)際相當(dāng)于插入一個結(jié)點(diǎn)操作) void putBuf(int type , buffer* buf) switch(type) case 0: if(buf != NULL) /該參數(shù)(buf)不為空的時候才執(zhí)行因?yàn)椴迦胍粋€空的緩沖區(qū)是沒有意義的 lemq-next = buf; /修正隊(duì)列尾指針 lemq = buf ; /隊(duì)尾指針的跟蹤 lemq-next = NULL; /隊(duì)列尾指針賦空 break; case 1: if(buf != NULL) /同上 linq-next = buf; linq = buf; linq-next = NULL; break; case 2: if(buf != NULL ) loutq-next = buf; loutq = buf; loutq-next = NULL; break; /構(gòu)造緩沖池函數(shù)的聲明 void ConstructBuffer() buffer *p , *q; / 為開辟動態(tài)緩沖區(qū)而設(shè)的兩個變量 hemq = new buffer; /創(chuàng)建空隊(duì)列的頭指針 hinq = new buffer; /創(chuàng)建輸入隊(duì)列的頭指針 houtq = new buffer; /創(chuàng)建輸出隊(duì)列的頭指針 q = he
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025至2030中國電子郵件簽名軟件行業(yè)產(chǎn)業(yè)運(yùn)行態(tài)勢及投資規(guī)劃深度研究報告
- 2025至2030中國電動鎖具行業(yè)市場深度分析及競爭格局與投資前景報告
- 2025至2030中國瑜伽短褲行業(yè)發(fā)展趨勢分析與未來投資戰(zhàn)略咨詢研究報告
- 2025至2030中國特級面粉行業(yè)市場深度研究與戰(zhàn)略咨詢分析報告
- 學(xué)習(xí)動機(jī)的強(qiáng)化策略教育心理學(xué)的視角
- 智能教育未來展望組委會的角色與影響
- 2025秋季教務(wù)處工作計(jì)劃:打造8大體系 培育時代新人
- 數(shù)字化教育資源的建設(shè)與共享
- 抖音商戶短視頻拍攝流程標(biāo)準(zhǔn)化規(guī)定
- 抖音商戶數(shù)據(jù)分析師用戶分層運(yùn)營制度
- 《中華民族共同體概論》考試復(fù)習(xí)題庫(含答案)
- PTBD管路維護(hù)技術(shù)
- 220kV變電運(yùn)行中的故障排除方法
- 30題投資管理類崗位常見面試問題含HR問題考察點(diǎn)及參考回答
- 煤礦典型事故案例分析培訓(xùn)課件
- 15D501 建筑物防雷設(shè)施安裝
- 電氣設(shè)備運(yùn)行與維護(hù)-開關(guān)電器的運(yùn)行與維護(hù)
- 決策力和執(zhí)行力教學(xué)課件
- 試產(chǎn)總結(jié)報告模板
- 滁州景航農(nóng)業(yè)科技有限公司蚯蚓養(yǎng)殖、玉米、菌菇種植協(xié)同處理處置秸稈、畜禽糞便和生活污泥項(xiàng)目環(huán)境影響報告表
- 醫(yī)院崗位系數(shù)評價實(shí)施辦法
評論
0/150
提交評論