银行家算法设计.docx
- 文档编号:29638858
- 上传时间:2023-07-25
- 格式:DOCX
- 页数:15
- 大小:93.06KB
银行家算法设计.docx
《银行家算法设计.docx》由会员分享,可在线阅读,更多相关《银行家算法设计.docx(15页珍藏版)》请在冰豆网上搜索。
银行家算法设计
一.设计目的:
1、银行家算法是避免死锁的一种重要方法,本实验要求用高级语言编写和调试一个简单的银行家算法程序。
加深了解有关资源申请、避免死锁等概念,并体会和了解死锁和避免死锁的具体实施方法。
2、提高学生的程序设计能力、提高算法设计质量与程序设计素质。
二.设计内容:
假设有n个进程m类资源,则有如下数据结构:
可利用资源向量Available。
这是一个含有m个元素的数组,其中的每一个元素代表一类可利用的资源数目,其初始值是系统中所配置的该类全部可用资源的数目,其数值随该类资源的分配和回收而动态地改变。
Available[j]=K,则表示系统中现有Rj类资源K个。
最大需求矩阵Max。
这是一个n*m的矩阵,它定义了系统中n个进程中的每一个进程对m类资源的最大需求。
如果Max[i,j]=K,则表示进程i需要Rj类资源的最大数目为K。
分配矩阵Allocation。
这也是一个n*m的矩阵,它定义了系统中每一类资源当前已分配给每一进程的资源数。
如果Allocation[i,j]=K,则表示进程i当前已分得Rj类资源的数目为K。
需求矩阵Need。
这也是一个n*m的矩阵,用以表示每一个进程尚需的各类资源数。
如果Need[i,j]=K,则表示进程i还需要Rj类资源K个,方能完成其任务。
上述三个矩阵存在如下关系:
Need[i,j]=Max[i,j]-Allocation[i,j]
三.设计过程
1、实现功能
voidshowdata()//函数showdata,输出资源分配情况
voidchangdata()//进行资源分配
voidsafe()//安全性算法,检验是否安全状态
voidshare()//利用银行家算法对申请资源对进行判定
2、添加功能
1、以用户输入的方式提出资源请求,并用银行家算法避免可能发生的死锁,若系统安全,允许用户继续申请资源。
2、与用户的交互界面友好,能动态地实现资源的修改和分配,动态的增加进程。
3、能计算安全系列并输出。
voidchangeresources()//修改资源函数
voiddelresources()//删除资源
voidaddprocess()//添加作业
3、设计思路
银行家算法是一种最有代表性的避免死锁的算法。
要解释银行家算法,必须先解释操
作系统安全状态和不安全状态安全状态:
如果存在一个由系统中所有进程构成的安全序列P1,…,Pn,则系统处于安全状态。
安全状态一定是没有死锁发生。
不安全状态:
不存在一个安全序列。
不安全状态不一定导致死锁。
那么什么是安全序列呢?
安全序列:
一个进程序列{P1,…,Pn}是安全的,如果对于每一个进程Pi(1≤i≤n),它以后尚需要的资源量不超过系统当前剩余资源量与所有进程Pj(j
我们可以把操作系统看作是银行家,操作系统管理的资源相当于银行家管理的资金,进程向操作系统请求分配资源相当于用户向银行家贷款。
操作系统按照银行家制定的规则为进程分配资源,当进程首次申请资源时,要测试该进程对资源的最大需求量,如果系统现存的资源可以满足它的最大需求量则按当前的申请量分配资源,否则就推迟分配。
当进程在执行中继续申请资源时,先测试该进程已占用的资源数与本次申请的资源数之和是否超过了该进程对资源的最大需求量。
若超过则拒绝分配资源,若没有超过则再测试系统现存的资源能否满足该进程尚需的最大资源量,若能满足则按当前的申请量分配资源,否则也要推迟分配。
4、算法和流程图
算法:
编制银行家算法通用程序,并检测所给状态的系统安全性。
设进程I提出请求Request[N],则银行家算法按如下规则进行判断。
(1)如果Request[N]<=NEED[I,N],则转
(2);否则,出错。
(2)如果Request[N]<=AVAILABLE,则转(3);否则,出错。
(3)系统试探分配资源,修改相关数据:
AVAILABLE=AVAILABLE-REQUEST
ALLOCATION=ALLOCATION+REQUEST
NEED=NEED-REQUEST
(4)系统执行安全性检查,如安全,则分配成立;否则试探险性分配作废,系统恢复原状,进程等待。
流程图:
四.各程序主要函数及注释
#include
#include
usingnamespacestd;
#defineFalse0
#defineTrue1
intMax[100][100]={0};//各进程所需各类资源的最大需求
intAvaliable[100]={0};//系统可用资源
charname[100];//资源的名称
intAllocation[100][100]={0};//系统已分配资源
intNeed[100][100]={0};//还需要资源
intRequest[100]={0};//请求资源向量
inttemp[100]={0};//存放安全序列
intWork[100]={0};//存放系统可提供资源
intM=100;//作业的最大数为100
intN=100;//资源的最大数为100
voidshowdata()//显示资源矩阵
{
inti,j;
cout<<"系统目前可用的资源[Avaliable]:
"< for(i=0;i cout< cout< for(j=0;j cout< cout< cout<<"MaxAllocationNeed"< cout<<"进程名"; for(j=0;j<3;j++) { for(i=0;i cout< cout<<""; } cout< for(i=0;i { cout<<"p"< for(j=0;j cout< cout<<""; for(j=0;j cout< cout<<""; for(j=0;j cout< cout< } } intchangdata(inti)//进行资源分配 { intj; for(j=0;j { Avaliable[j]=Avaliable[j]-Request[j]; Allocation[i][j]=Allocation[i][j]+Request[j]; Need[i][j]=Need[i][j]-Request[j]; } return1; } intsafe()//安全性算法 { inti,k=0,m,apply,Finish[100]={0}; intj; intflag=0; Work[0]=Avaliable[0]; Work[1]=Avaliable[1]; Work[2]=Avaliable[2]; for(i=0;i { apply=0; for(j=0;j { if(Finish[i]==False&&Need[i][j]<=Work[j]) { apply++; if(apply==N) { for(m=0;m Work[m]=Work[m]+Allocation[i][m];//变分配数 Finish[i]=True; temp[k]=i; i=-1; k++; flag++; } } } } for(i=0;i { if(Finish[i]==False) { cout<<"系统不安全! "< return-1; } } cout<<"系统是安全的! "< cout<<"分配的序列: "; for(i=0;i { cout< if(i } cout< return0; } voidshare()//利用银行家算法对申请资源对进行判定 { charch; inti=0,j=0; ch='y'; cout<<"请输入要求分配的资源进程号(0-"< "; cin>>i;//输入须申请的资源号 cout<<"请输入进程"< "< for(j=0;j { cout< "; cin>>Request[j];//输入需要申请的资源 } for(j=0;j { if(Request[j]>Need[i][j])//判断申请是否大于需求,若大于则出错 { cout<<"进程"< cout<<"分配不合理,不予分配! "< ch='n'; break; } else { if(Request[j]>Avaliable[j])//判断申请是否大于当前资源,若大于则出错 { cout<<"进程"< cout<<"分配出错,不予分配! "< ch='n'; break; } } } if(ch=='y') { changdata(i);//根据进程需求量变换资源 showdata();//根据进程需求量显示变换后的资源 safe();//根据进程需求量进行银行家算法判断 } } voidchangeresources()//修改资源函数 { inti,k; cout<<"系统目前可用的资源[Avaliable]: "< for(i=0;i cout< "< cout<<"重新输入系统可用资源[Avaliable]: "< for(i=0;i cin>>Avaliable[i]; cout<<"经修改后的系统可用资源为"< for(k=0;k cout< "< showdata(); safe(); } voiddelresources()//删除资源 { charming; inti,flag=1,j; cout<<"请输入需要删除的资源名称: "; do { cin>>ming; for(i=0;i if(ming==name[i]) { flag=0; break; } if(i==N) cout<<"该资源名称不存在,请重新输入: "; } while(flag); for(j=i;j { name[j]=name[j+1]; Avaliable[j]=Avaliable[j+1]; } intk=i; for(i=0;i { for(j=k;j { Max[i][j]=Max[i][j+1]; Allocation[i][j]=Allocation[i][j+1]; Need[i][j]=Need[i][j+1]; } } N=N-1; showdata(); safe(); } voidaddprocess()//添加作业 { intflag=M; M=M+1; cout<<"请输入该进程的最大需求量[Max]"< for(inti=0;i { cout< "; cin>>Max[flag][i]; Need[flag][i]=Max[flag][i]-Allocation[flag][i]; } showdata(); safe(); } intmain()//主函数 { //freopen("in.txt","r",stdin); inti,j,number,choice,m,n,flag; charming; cout<<"*****************资源管理系统的设计与实现*****************"< cout<<"请首先输入系统可供资源种类的数量: "; cin>>n; N=n; for(i=0;i { cout<<"资源"< "; cin>>ming; name[i]=ming; cout<<"资源的数量: "; getchar(); cin>>number; cout< Avaliable[i]=number; } cout< cout<<"请输入进程的数量: "; cin>>m; M=m; cout<<"请输入各进程的最大需求量("< "< for(i=0;i for(j=0;j cin>>Max[i][j]; do { flag=0; cout<<"请输入各进程已经申请的资源量("< "< for(i=0;i for(j=0;j { cin>>Allocation[i][j]; if(Allocation[i][j]>Max[i][j]) flag=1; Need[i][j]=Max[i][j]-Allocation[i][j]; } if(flag) cout<<"申请的资源大于最大需求量,请重新输入! \n"; } while(flag); showdata();//显示各种资源 safe();//用银行家算法判定系统是否安全 while(choice) { cout<<"*******************银行家算法演示*******************"< cout<<"*0: 退出程序1: 删除资源*"< cout<<"*2: 修改资源3: 分配资源*"< cout<<"*4: 增加进程*"< cout<<"****************************************************"< cout<<"请选择功能号: "; cin>>choice; switch(choice) { case1: delresources();break; case2: changeresources();break; case3: share();break; case4: addprocess();break; case0: choice=0;break; default: cout<<"请正确选择功能号(0-5)! "< } } return0; }
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 银行家 算法 设计