




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
淏 緒 需求分 設(shè)計內(nèi) 要求 總述 執(zhí)行過 詳細(xì)設(shè) 全局變 代碼塊分 主函數(shù)代碼 5代 進(jìn)程輸入輸 臨界資源管理(信號量 銀行家算法隨機分 銀行家算法避免死 運行截 心得體 設(shè)計內(nèi)1.不能重復(fù))、執(zhí)行時間和申請資源的等待時間等。在此同時可能有多個進(jìn)程在內(nèi)存申請某資源(5個)要總執(zhí)行過全局變#include<stdio.h>#include<ctype.h>#include<unistd.h>#include<sys/time.h>#include<stdlib.h>#include<pthread.h>#include<string.h>#defineNUM5資源數(shù)pthread_tthread[5];pthread_mutex_tmut互斥信號量structresource{chartype資源的名稱intn;//資源的數(shù)量structprocesscharnameintruntime;//執(zhí)行時間intwaittime等待時間inttypenumstructresourcer[5structyintflag;標(biāo)志,0:未出現(xiàn)過的資源,(aB1B1個)1intindex;資源下標(biāo)inttr;//進(jìn)程的下標(biāo)//}structprocessstructresourceRESOURCE[NUM每種資源的名稱及數(shù)量intu=0;//進(jìn)程數(shù)inta0;intAvailable[NUM可使用資源向量intMax[10][NUM];//最大需求矩陣intAllocation[10][NUM];//分配矩陣intNeed[10][NUM];//需求矩陣intWork[NUM];//工作向量intFinish[NUM狀態(tài)標(biāo)志];//函數(shù)代碼分布 inth=1,m,g;{ *成員:淏* printf("\n\n");{case1:scource();proceeding(); case2:signal();break;case{ *1:******************隨機輸 *2:*********************手動輸入 printf("\n\n");{case1:rands();h=1;break;case2:input();}case }} Seeyounexttime!!!\n\n\n");return0;}5代int{inti,x;{}{{}printf("請輸入資源%c:",ZY[i].type);{}}return}intjincheng(){inti=0;intj,g,x;char{}{printf("請輸入第%dn",i);{}{printf("請輸入進(jìn)程%c%cJC[i].name,JC[i].r[j].type);{}{printf("%c對資源%c的最大申請量大于資源%c的數(shù)量,請重新輸入: {}}}}return0;}臨界資源管理(信號量void{inti,j;int{{printf("%c所申請的%c資源數(shù)目大于現(xiàn)有的%c資源數(shù)目!,不能進(jìn)行分配gotoloop;}}{ZY[i].n-}{}{printf("%c(%d} {}}voidthread_create{intmemset(&thread,0,sizeof(thread))/*創(chuàng)建線程if((temp=pthread_create(&thread[0],NULL,thread1,NULL))!=printf("進(jìn)程%c!\n",JC[0].name);if((temp=pthread_create(&thread[1],NULL,thread2,NULL))!=printf("進(jìn)程%c!\n",JC[1].name);if((temp=pthread_create(&thread[2],NULL,thread3,NULL))!=printf("進(jìn)程%c!\n",JC[2].name);if((temp=pthread_create(&thread[3],NULL,thread4,NULL))!=if((temp=pthread_create(&thread[4],NULL,thread5,NULL))!=printf("進(jìn)程%c!\n",JC[4].name);}intjudge_pro(intm,intp[10]){inti,j;for(i=0;i<m;i++)for(j=0;j<p[i];j++){if(!(Y[i][j].flag1)){return11}}return0;}intpanduan1(inttr,intp[10]){intfor(i=0;i<p[tr];i++){if(!(Y[tr][i].flag1))return0;1}return1;}intra(){intinti,j,k=0,w=0,m=0,n=0,q=0;//k0if(u==0||a==0){return0;
for(i=0;i<u;i++)for(j=0;j<a;j++){if(Max[i][j]){Y[m][n].indexj;//indexY[m][n].tri;trY[m][n].flag=0;//flag=1:所記錄的資源已申請過,flag=0Y[m][n].flag1=0;//flag1=1:進(jìn)程對該資源的申請已達(dá)到所需量,flag=0:}}
col[m]n;colYn0;n}while(judge_pro(m,col)){int_one=0;inttr;do{tr=rand()%}while(panduan1(tr,col));printf("%c\n",JC[Y[tr][0].tr].name);intx=col[tr];for(i0;icol[tr];iif(Y[tr][i].flag1)x--}for(i=0;i<x;i++)do{jrand()(col[tr]);jY[trwhile(_one==j)jrand()(col[tr]);jY[tr}_one=}while(Y[tr][j].flag&&Y[tr][j].flag1;printf("%cZY[Y[tr][j].index].type);w=+%-printf("%dRequest[Y[tr][0].tr][Y[tr][j].indexw;Request}request(Y[tr][0].trcol[trtr);if(panduan1(tr,col)){printf("進(jìn)程%c}}if(!(judge_pro(m,col))){for(i=0;i<a;i++){Allocation[j][i]=Need[j][i]=Max[j][i]-}}return}intrequest(inttr,intz,intr){{printf("請先輸入信息!\n");return}{}{printf("\n\n");}{Work[i]=Available[iWork[i}{{ {if(Need[i][j]<={}{{Work[l]
溫馨提示
- 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年湖北國土資源職業(yè)學(xué)院單招職業(yè)技能測試題庫及參考答案
- 商業(yè)綜合體改造抵押協(xié)議
- 2025年度養(yǎng)豬場動物疫病監(jiān)測與預(yù)警協(xié)議
- 2025年度個人信息保護與信息安全保密協(xié)議書
- 二零二五年度食品飲料企業(yè)財務(wù)代理記帳服務(wù)合同
- 2025年廣西自然資源職業(yè)技術(shù)學(xué)院單招職業(yè)技能測試題庫及答案一套
- 商業(yè)廣場改造貸款協(xié)議
- 2025年度公司終止職工勞動合同解除與就業(yè)援助合同
- 2025年北京綠色生態(tài)居住區(qū)拆遷補償與生態(tài)修復(fù)合同
- 2025年度商鋪轉(zhuǎn)租定金及租賃期終止處理合同
- mks spectra介紹殘余氣體分析儀
- 腹腔鏡下闌尾切除術(shù)護理課件
- 《抖音生活服務(wù)服務(wù)商合作手冊》
- 語文教學(xué)設(shè)計(教案目標(biāo))
- 中山大學(xué)抬頭信紙中山大學(xué)橫式便箋紙推薦信模板a
- 無形資產(chǎn)評估完整版課件
- 一體化學(xué)工服務(wù)平臺、人事管理系統(tǒng)、科研管理系統(tǒng)建設(shè)方案
- 市場營銷學(xué)課后習(xí)題與答案
- 常暗之廂(7規(guī)則-簡體修正)
- 制冷系統(tǒng)方案的設(shè)計pptx課件
- 修心七要原文
評論
0/150
提交評論