版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
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í)際問(wèn)題;(2)了解windows系統(tǒng)或unix/linux系統(tǒng)下中信號(hào)量的使用方法。2實(shí)驗(yàn)內(nèi)容編寫(xiě)一個(gè)有關(guān)生產(chǎn)者和消費(fèi)者的程序:每個(gè)生產(chǎn)者每次生產(chǎn)一個(gè)產(chǎn)品存入倉(cāng)庫(kù),每個(gè)消費(fèi)者每次從倉(cāng)庫(kù)中取出一個(gè)產(chǎn)品進(jìn)行消費(fèi),倉(cāng)庫(kù)大小有限,每次只能有一個(gè)生產(chǎn)者或消費(fèi)者訪問(wèn)倉(cāng)庫(kù)。要求:采用信號(hào)量機(jī)制。3、環(huán)境說(shuō)明本實(shí)驗(yàn)是在win7環(huán)境下使用dev編譯器實(shí)現(xiàn)的,采用Win API的信號(hào)量機(jī)制。4、程序設(shè)計(jì)說(shuō)明該程序根據(jù)教材中的消費(fèi)者生產(chǎn)者問(wèn)題編寫(xiě)的,使用了教材中提供的框架思路以及庫(kù)函數(shù),使用 Cr
2、eateThread建立新的線程,使用CreateMutex創(chuàng)建一個(gè)互斥信號(hào)量,使用CreateSemaphore創(chuàng)建信號(hào)量,使用ReleaseMutex釋放線程的互斥信號(hào)量,使用ReleaseSemaphore對(duì)指定的信號(hào)量增加指定的值,使用WaitForSingleObject等待空位,使用CloseHandle在操作結(jié)束后關(guān)閉線程和信號(hào)量。在這個(gè)程序里我設(shè)計(jì)了三個(gè)函數(shù): Int main()是主函數(shù),其中包含了緩沖區(qū)大小的設(shè)置,生產(chǎn)者消費(fèi)者發(fā)出請(qǐng)求等內(nèi)容以及線程創(chuàng)建等內(nèi)容DWORD WINAPI producer(LPVOID lpPara)是生產(chǎn)者等待緩沖區(qū)的使用權(quán)并對(duì)緩沖區(qū)進(jìn)行操作D
3、WORD WINAPI consumer(LPVOID lpPara)是消費(fèi)者等待緩沖區(qū)的使用權(quán)并對(duì)緩沖區(qū)進(jìn)行操作 該程序模擬生產(chǎn)者消費(fèi)者問(wèn)題,首先要設(shè)置緩沖區(qū)的大小,輸入請(qǐng)求資源的各個(gè)進(jìn)程的信息以及請(qǐng)求時(shí)間,并且按照請(qǐng)求時(shí)間對(duì)各進(jìn)程進(jìn)行排序,創(chuàng)建線程,然后按序依次對(duì)緩沖區(qū)進(jìn)行操作,詳細(xì)設(shè)計(jì)見(jiàn)源代碼。5、程序運(yùn)行結(jié)果截圖:只有生產(chǎn)者請(qǐng)求,沒(méi)有消費(fèi)者請(qǐng)求,請(qǐng)求滿足只有消費(fèi)者請(qǐng)求,沒(méi)有生產(chǎn)者請(qǐng)求,消費(fèi)者的請(qǐng)求不成功:生產(chǎn)者請(qǐng)求大于消費(fèi)者請(qǐng)求并且消費(fèi)者請(qǐng)求在生產(chǎn)者放入產(chǎn)品之后:消費(fèi)者請(qǐng)求多于生產(chǎn)者請(qǐng)求,只能滿足部分消費(fèi)者請(qǐng)求,不能滿足全部: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)者的類(lèi)型 int seq; /記錄請(qǐng)求次序 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號(hào)產(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號(hào)產(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("請(qǐng)?jiān)O(shè)置緩
8、沖區(qū)大?。?quot;); scanf("%d",&buf_size); printf("請(qǐng)輸入請(qǐng)求使用資源進(jìn)程的個(gè)數(shù):"); scanf("%d",&req_size); for(i=0;i<req_size;i+) printf("請(qǐng)選擇是消費(fèi)者進(jìn)程(0)還是生產(chǎn)者進(jìn)程(1):"); scanf("%d",&reqi.type); printf("請(qǐng)輸入該進(jìn)程的請(qǐng)求時(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ǐng)求從緩沖區(qū)中取產(chǎn)品,請(qǐng)求時(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ǐng)求往緩沖區(qū)中放產(chǎn)品,請(qǐng)求時(shí)間為%dn",reqi.seq); result = WaitForMultipleObjects(req_size, thread, TRUE, 500); if (result = WAIT_TIMEOUT) printf("n請(qǐng)求不能被完全滿足n"); else printf("n能夠滿足所有請(qǐng)求 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)基于書(shū)上的生產(chǎn)者消費(fèi)者問(wèn)題,原理在上課的時(shí)候老師已
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度木結(jié)構(gòu)工程安全風(fēng)險(xiǎn)評(píng)估與管控合同
- 二零二五版航空航天設(shè)備采購(gòu)合同集2篇
- 二零二五年度跨境電商物流服務(wù)合同變更2篇
- 管理溝通培訓(xùn)
- 二零二五年度貨車(chē)貨運(yùn)配送承包合同3篇
- 基于2025年度財(cái)務(wù)預(yù)算的合同成本管理與優(yōu)化2篇
- 二零二五版環(huán)保項(xiàng)目墊資合同范本2篇
- 2025年度木材加工鋼材買(mǎi)賣(mài)居間合同附帶供應(yīng)鏈金融方案3篇
- 2025版小學(xué)校園廣播系統(tǒng)升級(jí)合同3篇
- 二零二五年度環(huán)保型城市綜合體安全施工環(huán)保合同2篇
- 《電影之創(chuàng)戰(zhàn)紀(jì)》課件
- 社區(qū)醫(yī)療抗菌藥物分級(jí)管理方案
- 開(kāi)題報(bào)告-鑄牢中華民族共同體意識(shí)的學(xué)校教育研究
- 《醫(yī)院標(biāo)識(shí)牌規(guī)劃設(shè)計(jì)方案》
- 夜市運(yùn)營(yíng)投標(biāo)方案(技術(shù)方案)
- 電接點(diǎn) 水位計(jì)工作原理及故障處理
- 國(guó)家職業(yè)大典
- 動(dòng)火作業(yè)審批表
- 新能源汽車(chē)火災(zāi)事故處置程序及方法
- 教育家精神六個(gè)方面專(zhuān)題PPT
- 教學(xué)查房及體格檢查評(píng)分標(biāo)準(zhǔn)
評(píng)論
0/150
提交評(píng)論