能运行的银行家算法

上传人:大米 文档编号:473326543 上传时间:2024-03-01 格式:DOC 页数:8 大小:22.50KB
返回 下载 相关 举报
能运行的银行家算法_第1页
第1页 / 共8页
能运行的银行家算法_第2页
第2页 / 共8页
能运行的银行家算法_第3页
第3页 / 共8页
能运行的银行家算法_第4页
第4页 / 共8页
能运行的银行家算法_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《能运行的银行家算法》由会员分享,可在线阅读,更多相关《能运行的银行家算法(8页珍藏版)》请在金锄头文库上搜索。

1、#icudesti.h#define SE 0#defin RUE defin 10#ene R 2int M ; /*总进程数/i N ; /*资源种类/intAL_REOURC;/多种资源的数目总和*/nt MAXW; *M个进程对N类资源最大资源需求量/intAVILBLER;/*系统可用资源数/in ALLOCAIOR;/个进程已经得到N类资源的资源量*it NEEDR; *个进程还需要N类资源的资源量*int REUEST; /祈求资源个数*/*函数名:output*功能:输出资源分派状况*/oid ouput()t i,j;print(All Rsorce:n);fr(j=0 ;

2、j N;j+)rintf(R%d:%dn, j , AL_REOUR);pritf(Reourc Available:n);or(j =0; ; j+)printf(%d:%dn, j , IABLEj);ptf(rocessesourcNeeded:);prit(|PID|);for(j = 0 ; jN ; j+)prnt(R%d |, j);rint(n);for( = ;i ; +)or( 0 ; i ; +)print(|-5d|, );fo(j = 0 ; j N ; j+)prinf(%-4|, EEDi);pritf();rintf(PrcRsoucellcated:n);pr

3、int(| PID|);fo( = 0 ; ; j+)printf(R%d |, j);prinf();or(i = ; i M;i+) rnt(|%5|, i);for(j = 0 ; j N;j+)printf(-d, ALOONi); rintf(n);/*otu*/函数名 :dify*功能:变化可用资源和已经拿到资源和还需要的资源的值参数:ntk 修改编号为K的的数据*/voidmodify(nt k)in ;fr( =0 ;j N ; j+)/修改数据* AAILABLE= VLABLEj RQETj;/修改可用资源*/ ALLOCATINkj = ALCATINj + RQUETj

4、;/*修改分派资源/NEEDkj =NEDkj - EQUSTj;/*修改资源需求*/*函数名:udo*功能:还原可用资源和已经拿到资源和还需要的资源的值参数:参数:int 修改编号为的的数据/void undo(i k)intj;fo(j = 0 ; j N;j+)/修改数据/ AVAILBE = AVILABLE + RUESTj; /修改可用数据* ALCATNkj ALLOCTIOk- EUSTj; /*修改分派的资源* NEkj=NEEDkj+ REQTj;/修改资源需求*/ /*函数名:chkrr*功能:检查修改操作与否安全*int chkerr(int s)i WORK , FI

5、NIHW;n i ,j;fr(i = 0; i ;+)/清空FIIS*/FIISHi = FALSE;fr(j= 0;j N ; +)/逐个检查*/WORK = AVALABLEj; s;do(FINISHi =FALSE & NEDij = ORK)/*符合条件?*WRK= WO+ ALOCATIOj;FNSHi TR; = 0;esi+;wile(iM);fo(i =;i M;i)/*只要一种不满足,不安全*/if(FIHi = ALSE)rintf(Error: Sfe llocaio!n);return1;printf(OK: llaonK);reurn 0;/*函数名:bnk*功能

6、:银行家算法的实现*/void ak()nt i , j;int fla=TRUE;pitf(e Ctrl+C beakn);while(TRUE) ;hi(i = M)rintf(Inut Process to Alloc D=);scanf(%, &i);if(i = M)intf(Error:Invlid nput!);rif(nut Resurce een);fo (j = 0 ; NEi)/*祈求的资源数不小于祈求资源/print(Error: Invald ut!);lag LS;elsef(REUESTjAVAILABLEj)/*若祈求的资源数不小于可用资源数*/pintf(Er

7、o: InalidInput!n);flag= FAE;*else* /*for*/ f(flag) fy(); /*修改资源数if(cerr(i)/*安全?*/ud(i); /*恢复资源数/outpu();*输出*lseoutpt();/输出/ eseouut();/*whi*/*bak*/*主函数*/int main()in , j, p;pit(InputProcess Nubers =);/*进程数量*/ca(%, );prntf(nut Rsource Cagory N);/*资源种类scanf(,&N);rintf(InpuNumber of llRoe ech Cteo:);*资

8、源数目*/for(i=0 ; N ;i+)scanf(%, A_EOUCE);pritf(Inpu Max euce Procss Nee:n);/*最大资源需求*/fr (i = 0 ; i AL_SORCEj)/*不小于最大可用?*pinf(nError:nalidnpt!n); whie (MAij ALL_ESOEj);*for*/rntf(Inputesouce ProcssAllocd:n);for (i =0; i ; i)fr (j ; j MAXi);/*fo/o(j 0; j N ; +)p= AL_RESORCEj;fr(i=0 ;i M ; i+)pALOCATIOij;/*减去已经分派资源*/VAIEj= ;i(AVILALEj0)AVAILAE 0;/清理数据*/*for/*for*/for (i=; i M ;+)for(j ; j N ; j+)NEj = MAXij-ALLOCATONij;/*求还需要的资源*/oup();ank();*银行家算法*/etu0;/*ain*

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 活动策划

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号