银行家算法实现一.相关原理银行家算法是避免死锁的一种重要方法,通过编写一个简单的银行家算法程序,加深了解有关资源申请、避免死锁等概念,并体会和了解死锁和避免死锁的具体实施方法。死锁的产生,必须同时满足四个条件,即一个资源每次只能由一个进程所用;第二个为等待条件,即一个进程请求资源不能满足时,它必须等待,单它仍继续宝石已得到的所有其他资源;第三个为非剥夺条件,即在出现死锁的系统中一定有不可剥夺使用的资源;第四个为循环等待条件,系统中存在若干个循环等待的进程,即其中每一个进程分别等待它前一个进程所持有的资源。防止死锁的机构只能确保上述四个条件之一不出现,则系统就不会发生死锁。通过这个算法可以用来解决生活中的实际问题,如银行贷款等。二.程序流程图:1.初始化算法流程图:2.银行家算法流程图:3.安全性算法流程图:三.程序的实现#includeiostreamusingnamespacestd;intmain(){intm,n,t,i,j,a[100],p=0,q,work[100],need[100][100];intavaliable[100],max[100][100],allocation[100][100],request[100][100];charch='Y';cinm;//m种资源cinn;//n个进程for(i=0;im;i++)//每种资源的可用数目cinavaliable[i];for(i=0;in;i++){a[i]=i;for(j=0;jm;j++)//最大需求量cinmax[i][j];for(j=0;jm;j++){cinallocation[i][j];//已分配量need[i][j]=max[i][j]-allocation[i][j];}}for(i=0;im;i++)//m种资源{for(j=0;jn;j++)//n个进程avaliable[i]=avaliable[i]-allocation[j][i];}while(ch=='Y'||ch=='y'){p=0;cout请输入进程号和对每类资源的请求数:endl;cint;t--;for(j=0;jm;j++)cinrequest[t][j];intflag=1;for(j=0;jm;j++){if(request[t][j]need[t][j]){flag=0;break;}}for(j=0;jm;j++){if(request[t][j]avaliable[j]){flag=0;break;}}if(flag==1){for(i=0;im;i++){avaliable[i]=avaliable[i]-request[t][i];work[i]=avaliable[i];allocation[t][i]=allocation[t][i]+request[t][i];need[t][i]=need[t][i]-request[t][i];}}else{coutInputErrorendl;gotoA;}for(j=0;jn;j++){for(i=0;in;i++){if(a[i]=0){intflag=1;for(q=0;qm;q++){if(need[i][q]work[q]){flag=0;break;}}if(flag==1){p++;for(q=0;qm;q++){work[q]=work[q]+allocation[i][q];}a[i]=-1;}}}}if(p==n){coutYesendl;for(i=0;in;i++){for(j=0;jm;j++)//最大需求量coutmax[i][j];for(j=0;jm;j++){coutallocation[i][j];//已分配量}for(j=0;jm-1;j++){coutneed[i][j];//需求量}//coutendl;coutneed[i][j]endl;}for(j=0;jm-1;j++){coutavaliable[j];//可用资源数}coutavaliable[j]endl;}else{coutWaitendl;for(i=0;im;i++){avaliable[i]=avaliable[i]+request[t][i];allocation[t][i]=allocation[t][i]-request[t][i];need[t][i]=need[t][i]+request[t][i];}A:for(i=0;in;i++){for(j=0;jm;j++)//输出最大需求量coutmax[i][j];for(j=0;jm;j++){coutallocation[i][j];//输出已分配量}for(j=0;jm-1;j++){coutneed[i][j];//输出需求量}//coutendl;coutneed[i][j]endl;}for(j=0;jm-1;j++){coutavaliable[j];//输出可用资源数}coutavaliable[j]endl;}cout是否要继续Y/Nendl;cinch;}return0;}操作输出结果:四.实验心得银行家算法的模拟实现”是本学期操作系统课程中重要的课程设计。在设计此程序的过程中,我遇到过许多问题,也学到了很多东西。本程序的设计实现主要是用C++语言实现,通过对程序算法的设计优化、输出显示的格式设计、输入过程中的异常处理等一些设计过程中的问题的考虑解决,在C++学习上也有了很大的进步。程序设计过程中开始遇到的最大的问题是算法的结构设计问题,课本上只给了设计要求及简单的算法,要真正实现还需要考虑很多方面。在算法的数据结构设计上考虑了很长时间。在程序设计中先后参考了很多网络资料,也参考了一些别人写的的程序,综合这些算法思想和自己的思路对程序做了很好的设计方式,对一些算法的优越性等也作了一些考虑。此外考虑最多的就是异常错误处理的设计。一个好的程序必须能在各种环境下都有其相应的处理方式,至少能应对一些常见的可能发生的错误。比如一般的要求输入为数字时,如果输入了一个非数字字符,程序就会立即出错无法继续运行,本程序针对这个问题设计了一个shuzi();函数进行处理,处理方式为:接受键盘输入的字符为字符串,然后对字符串的每个字符进行判断是否为数字,如果有非数字字符出现则提示出错并要求重新输入。又如在判断是否继续时要求输入Y/N时,按一般的方式,如果输入为多个字符,则多余的字符会保存在缓冲区,到下次要求输入时输入而导致出错,对此问题设计处理方式为接受输入字符保存为串然后只取其首字符进行判断。还有很多类似的错误处理。还有在设置程序的显示优化时,发现暂停函数在不同的情况下执行顺序不同,如此等等。在课程设计过程中遇到了许多问题,也向同宿舍的同学做了一些请教一起讨论,也因此从他们身上学到了许多东西。