版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上進(jìn)程管理實(shí)驗(yàn)報(bào)告1實(shí)驗(yàn)?zāi)康模海?)理解進(jìn)程/線程同步的方法,學(xué)會(huì)運(yùn)用進(jìn)程/線程同步的方法解決實(shí)際問題;(2)了解windows系統(tǒng)或unix/linux系統(tǒng)下中信號量的使用方法。2實(shí)驗(yàn)內(nèi)容編寫一個(gè)有關(guān)生產(chǎn)者和消費(fèi)者的程序:每個(gè)生產(chǎn)者每次生產(chǎn)一個(gè)產(chǎn)品存入倉庫,每個(gè)消費(fèi)者每次從倉庫中取出一個(gè)產(chǎn)品進(jìn)行消費(fèi),倉庫大小有限,每次只能有一個(gè)生產(chǎn)者或消費(fèi)者訪問倉庫。要求:采用信號量機(jī)制。3、環(huán)境說明本實(shí)驗(yàn)是在win7環(huán)境下使用dev編譯器實(shí)現(xiàn)的,采用Win API的信號量機(jī)制。4、程序設(shè)計(jì)說明該程序根據(jù)教材中的消費(fèi)者生產(chǎn)者問題編寫的,使用了教材中提供的框架思路以及庫函數(shù),使用 Cr
2、eateThread建立新的線程,使用CreateMutex創(chuàng)建一個(gè)互斥信號量,使用CreateSemaphore創(chuàng)建信號量,使用ReleaseMutex釋放線程的互斥信號量,使用ReleaseSemaphore對指定的信號量增加指定的值,使用WaitForSingleObject等待空位,使用CloseHandle在操作結(jié)束后關(guān)閉線程和信號量。在這個(gè)程序里我設(shè)計(jì)了三個(gè)函數(shù): Int main()是主函數(shù),其中包含了緩沖區(qū)大小的設(shè)置,生產(chǎn)者消費(fèi)者發(fā)出請求等內(nèi)容以及線程創(chuàng)建等內(nèi)容DWORD WINAPI producer(LPVOID lpPara)是生產(chǎn)者等待緩沖區(qū)的使用權(quán)并對緩沖區(qū)進(jìn)行操作D
3、WORD WINAPI consumer(LPVOID lpPara)是消費(fèi)者等待緩沖區(qū)的使用權(quán)并對緩沖區(qū)進(jìn)行操作 該程序模擬生產(chǎn)者消費(fèi)者問題,首先要設(shè)置緩沖區(qū)的大小,輸入請求資源的各個(gè)進(jìn)程的信息以及請求時(shí)間,并且按照請求時(shí)間對各進(jìn)程進(jìn)行排序,創(chuàng)建線程,然后按序依次對緩沖區(qū)進(jìn)行操作,詳細(xì)設(shè)計(jì)見源代碼。5、程序運(yùn)行結(jié)果截圖:只有生產(chǎn)者請求,沒有消費(fèi)者請求,請求滿足只有消費(fèi)者請求,沒有生產(chǎn)者請求,消費(fèi)者的請求不成功:生產(chǎn)者請求大于消費(fèi)者請求并且消費(fèi)者請求在生產(chǎn)者放入產(chǎn)品之后:消費(fèi)者請求多于生產(chǎn)者請求,只能滿足部分消費(fèi)者請求,不能滿足全部:6、源代碼:#include <cstdio>#
4、include <cstdlib>#include <cstring>#include <iostream>#include <algorithm>#include <windows.h>using namespace std;#define MAX_BUF 1000#define MAX_REQ 20 HANDLE mutex;HANDLE full;HANDLE empty; HANDLE threadMAX_REQ;DWORD pro_idMAX_REQ;DWORD con_idMAX_REQ;struct request in
5、t type;/記錄生產(chǎn)者消費(fèi)者的類型 int seq; /記錄請求次序 reqMAX_REQ; int buf_size; int req_size; int no;int bufferMAX_BUF;int in;int out; int result;bool cmp(request a,request b) return a.seq<b.seq; DWORD WINAPI producer(LPVOID lpPara) WaitForSingleObject(full,INFINITE); WaitForSingleObject(mutex,INFINITE); printf(&
6、quot;生產(chǎn)者%d將第%d號產(chǎn)品放入緩沖區(qū)n",(int)lpPara,no); bufferin=no+; in=(in+1)%buf_size; printf("成功放入緩沖區(qū)!nn",(int)lpPara); ReleaseMutex(mutex); ReleaseSemaphore(empty,1,NULL); return 0; DWORD WINAPI consumer(LPVOID lpPara) WaitForSingleObject(empty,INFINITE); WaitForSingleObject(mutex,INFINITE); p
7、rintf("消費(fèi)者%d將第%d號產(chǎn)品從緩沖區(qū)取出n",(int)lpPara,bufferout); bufferout=0; printf("成功從緩沖區(qū)取出!nn",(int)lpPara); ReleaseMutex(mutex); out=(out+1)%buf_size; ReleaseSemaphore(full,1,NULL); return 0; int main() int i; int p=0; no = 1; in=out=0; memset(buffer, 0, sizeof(buffer); printf("請?jiān)O(shè)置緩
8、沖區(qū)大?。?quot;); scanf("%d",&buf_size); printf("請輸入請求使用資源進(jìn)程的個(gè)數(shù):"); scanf("%d",&req_size); for(i=0;i<req_size;i+) printf("請選擇是消費(fèi)者進(jìn)程(0)還是生產(chǎn)者進(jìn)程(1):"); scanf("%d",&reqi.type); printf("請輸入該進(jìn)程的請求時(shí)間:"); scanf("%d",&reqi.s
9、eq); sort(req,req+req_size,cmp); mutex=CreateMutex(NULL,FALSE,NULL); full=CreateSemaphore(NULL,buf_size,buf_size,NULL); empty=CreateSemaphore(NULL,0,buf_size,NULL); for(i=0;i<req_size;i+) if(reqi.type=0) threadi=CreateThread(NULL, 0, consumer, (LPVOID)i, 0, &con_idi); if(threadi=NULL) return
10、-1; printf("n消費(fèi)者請求從緩沖區(qū)中取產(chǎn)品,請求時(shí)間為%dn",reqi.seq); if(reqi.type=1) threadi=CreateThread(NULL,0,producer,(LPVOID)i,0,&pro_idi); if(threadi=NULL) return -1; printf("n生產(chǎn)者請求往緩沖區(qū)中放產(chǎn)品,請求時(shí)間為%dn",reqi.seq); result = WaitForMultipleObjects(req_size, thread, TRUE, 500); if (result = WAIT_TIMEOUT) printf("n請求不能被完全滿足n"); else printf("n能夠滿足所有請求 n"); for(int i=0; i<req_size; i+) CloseHandle(threadi); CloseHandle(mutex); CloseHandle(full); CloseHandle(empty); system("pause"); return 0;7、實(shí)驗(yàn)總結(jié): 本次實(shí)驗(yàn)基于書上的生產(chǎn)者消費(fèi)者問題,原理在上課的時(shí)候老師已
溫馨提示
- 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)僅提供信息存儲空間,僅對用戶上傳內(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度內(nèi)陸水路貨物運(yùn)輸代理合同樣本
- 二零二五年度廣告?zhèn)髅叫袠I(yè)設(shè)計(jì)人員派遣合同范本2篇
- 二零二五年度土地征收與補(bǔ)償安置合同模板
- 2025年度上市公司人事勞動(dòng)合同模板2篇
- 2025年度個(gè)人旅游線路設(shè)計(jì)服務(wù)合同4篇
- 二零二五年度電梯鋼結(jié)構(gòu)高空作業(yè)安全防護(hù)承包合同2篇
- 2025版智慧苗圃基地規(guī)劃設(shè)計(jì)施工一體化合同4篇
- 二零二五版內(nèi)墻批灰與智能家居照明系統(tǒng)合同4篇
- 課題申報(bào)參考:面向破損兵馬俑修復(fù)的碎片多尺度全局T o k e n掩碼學(xué)習(xí)分類研究
- 2025年度商鋪?zhàn)赓U合同(含租賃物安全責(zé)任)
- 社區(qū)醫(yī)療抗菌藥物分級管理方案
- 開題報(bào)告-鑄牢中華民族共同體意識的學(xué)校教育研究
- 《醫(yī)院標(biāo)識牌規(guī)劃設(shè)計(jì)方案》
- 公司2025年會(huì)暨員工團(tuán)隊(duì)頒獎(jiǎng)盛典攜手同行共創(chuàng)未來模板
- 新滬科版八年級物理第三章光的世界各個(gè)章節(jié)測試試題(含答案)
- 夜市運(yùn)營投標(biāo)方案(技術(shù)方案)
- 電接點(diǎn) 水位計(jì)工作原理及故障處理
- 國家職業(yè)大典
- 2024版房產(chǎn)代持協(xié)議書樣本
- 2024年3月計(jì)算機(jī)等級考試三級數(shù)據(jù)庫技術(shù)筆試真題及答案
- 公眾號運(yùn)營實(shí)戰(zhàn)手冊
評論
0/150
提交評論