![2015操作系統(tǒng)課設(shè)lixin實(shí)訓(xùn)名稱課程設(shè)計(jì)_第1頁(yè)](http://file4.renrendoc.com/view/73223591c4c87fb6531195a7eaad1c43/73223591c4c87fb6531195a7eaad1c431.gif)
![2015操作系統(tǒng)課設(shè)lixin實(shí)訓(xùn)名稱課程設(shè)計(jì)_第2頁(yè)](http://file4.renrendoc.com/view/73223591c4c87fb6531195a7eaad1c43/73223591c4c87fb6531195a7eaad1c432.gif)
![2015操作系統(tǒng)課設(shè)lixin實(shí)訓(xùn)名稱課程設(shè)計(jì)_第3頁(yè)](http://file4.renrendoc.com/view/73223591c4c87fb6531195a7eaad1c43/73223591c4c87fb6531195a7eaad1c433.gif)
![2015操作系統(tǒng)課設(shè)lixin實(shí)訓(xùn)名稱課程設(shè)計(jì)_第4頁(yè)](http://file4.renrendoc.com/view/73223591c4c87fb6531195a7eaad1c43/73223591c4c87fb6531195a7eaad1c434.gif)
![2015操作系統(tǒng)課設(shè)lixin實(shí)訓(xùn)名稱課程設(shè)計(jì)_第5頁(yè)](http://file4.renrendoc.com/view/73223591c4c87fb6531195a7eaad1c43/73223591c4c87fb6531195a7eaad1c435.gif)
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
淏 緒 需求分 設(shè)計(jì)內(nèi) 要求 總述 執(zhí)行過(guò) 詳細(xì)設(shè) 全局變 代碼塊分 主函數(shù)代碼 5代 進(jìn)程輸入輸 臨界資源管理(信號(hào)量 銀行家算法隨機(jī)分 銀行家算法避免死 運(yùn)行截 心得體 設(shè)計(jì)內(nèi)1.不能重復(fù))、執(zhí)行時(shí)間和申請(qǐng)資源的等待時(shí)間等。在此同時(shí)可能有多個(gè)進(jìn)程在內(nèi)存申請(qǐng)某資源(5個(gè))要總執(zhí)行過(guò)全局變#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互斥信號(hào)量structresource{chartype資源的名稱intn;//資源的數(shù)量structprocesscharnameintruntime;//執(zhí)行時(shí)間intwaittime等待時(shí)間inttypenumstructresourcer[5structyintflag;標(biāo)志,0:未出現(xiàn)過(guò)的資源,(aB1B1個(gè))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:******************隨機(jī)輸 *2:*********************手動(dòng)輸入 printf("\n\n");{case1:rands();h=1;break;case2:input();}case }} Seeyounexttime!!!\n\n\n");return0;}5代int{inti,x;{}{{}printf("請(qǐng)輸入資源%c:",ZY[i].type);{}}return}intjincheng(){inti=0;intj,g,x;char{}{printf("請(qǐng)輸入第%dn",i);{}{printf("請(qǐng)輸入進(jìn)程%c%cJC[i].name,JC[i].r[j].type);{}{printf("%c對(duì)資源%c的最大申請(qǐng)量大于資源%c的數(shù)量,請(qǐng)重新輸入: {}}}}return0;}臨界資源管理(信號(hào)量void{inti,j;int{{printf("%c所申請(qǐng)的%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:所記錄的資源已申請(qǐng)過(guò),flag=0Y[m][n].flag1=0;//flag1=1:進(jìn)程對(duì)該資源的申請(qǐng)已達(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("請(qǐng)先輸入信息!\n");return}{}{printf("\n\n");}{Work[i]=Available[iWork[i}{{ {if(Need[i][j]<={}{{Work[l]
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2023八年級(jí)歷史上冊(cè) 第五單元 從國(guó)共合作到國(guó)共對(duì)立第17課 中國(guó)工農(nóng)紅軍長(zhǎng)征說(shuō)課稿 新人教版
- 3 歡歡喜喜慶國(guó)慶(說(shuō)課稿)-2024-2025學(xué)年統(tǒng)編版道德與法治二年級(jí)上冊(cè)
- Module 3 Unit 1 What are you doing?(說(shuō)課稿)-2024-2025學(xué)年外研版(三起)英語(yǔ)四年級(jí)上冊(cè)
- 11《趙州橋》說(shuō)課稿-2023-2024學(xué)年統(tǒng)編版語(yǔ)文三年級(jí)下冊(cè)
- 1學(xué)會(huì)尊重(說(shuō)課稿)-2023-2024學(xué)年道德與法治六年級(jí)下冊(cè)統(tǒng)編版001
- Unit 3 Festivals and Customs Extended reading 說(shuō)課稿-2024-2025學(xué)年高中英語(yǔ)譯林版(2020)必修第二冊(cè)
- 2023九年級(jí)物理下冊(cè) 專題六 材料、信息和能源B 能源學(xué)說(shuō)課稿 (新版)新人教版
- 2023二年級(jí)數(shù)學(xué)下冊(cè) 六 田園小衛(wèi)士-萬(wàn)以內(nèi)的加減法(二)我學(xué)會(huì)了嗎說(shuō)課稿 青島版六三制
- 2024-2025學(xué)年高中化學(xué) 專題五 電化學(xué)問(wèn)題研究 5.1 原電池說(shuō)課稿 蘇教版選修6
- 《10 身邊的新聞?wù){(diào)查》(說(shuō)課稿)-2023-2024學(xué)年三年級(jí)上冊(cè)綜合實(shí)踐活動(dòng)吉美版
- 簡(jiǎn)易勞務(wù)合同電子版
- 明代文學(xué)緒論
- 通用稅務(wù)自查情況說(shuō)明報(bào)告(7篇)
- 體育賽事的策劃、組織與實(shí)施 體育賽事利益相關(guān)者
- 分析化學(xué)(高職)PPT完整版全套教學(xué)課件
- 晚熟的人(莫言諾獎(jiǎng)后首部作品)
- m拱頂儲(chǔ)罐設(shè)計(jì)計(jì)算書(shū)
- 2023外貿(mào)業(yè)務(wù)協(xié)調(diào)期中試卷
- 新人教鄂教版(2017)五年級(jí)下冊(cè)科學(xué)全冊(cè)教學(xué)課件
- GB/T 29361-2012電子物證文件一致性檢驗(yàn)規(guī)程
- GB/T 16475-1996變形鋁及鋁合金狀態(tài)代號(hào)
評(píng)論
0/150
提交評(píng)論