银行家算法及流程图

合集下载

银行家算法c语言流程图代码全

银行家算法c语言流程图代码全
操作系统教程
——银行家算法
院系 班级 学号 姓名
计算机与软件学院 08 软件工程 2 班
20081344066 何丽茗
一、实验目的
银行家算法是避免死锁的一种重要方法。通过编写一个模拟动态资源分配的银行家算法 程序�进一步深入理解死锁、产生死锁的必要条件、安全状态等重要概念�并掌握避免死锁 的具体实施方法。
四、实验代码以及运行示例
1. 源代码�
#include<iostream>
#include<string.h>
#include<stdio.h>
#define False 0
#define True 1
using namespace std;
intMax[100][100]={0};//各进程所需各类资源的最大需求
for(j=0;j<N;j++)
cout<<Allocation[i][j]<<" ";
cout<<" ";
for(j=0;j<N;j++)
cout<<Need[i][j]<<" ";
cout<<endl;
}
}
intchangdata(inti)//进行资源分配 {
int j; for (j=0;j<M;j++) {
Y
i加1
提示 错误 重新 输入
所有进程运行 都结束
结束
初始化 need 矩阵 Y Need 矩阵为 0
N
任选一个进程作为当前进程
Need 向量为 0 N

银行家算法

银行家算法

操作系统银行家算法课后作业一、实验目的加深对多实例资源分配系统中死锁避免方法——银行家算法的理解,掌握Windows 环境下银行家算法的实现方法。

强调对于资源的管理、申请、比较来避免出现死锁的情况,保证系统的正常运行。

二、实验内容1.在Windows 操作系统上,利用DEVC++编写应用程序实现银行家算法。

2.创建n 个线程来申请或释放资源,只有保证系统安全,才会批准资源申请。

三、实验步骤(一)设计思路:银行家算法可分为个主要的功能模块,其描述如下:1.初始化由用户输入数据,分别对运行的进程数、总的资源种类数、总资源数、各进程所需要的最大资源数量(Max),已分配的资源数量赋值。

2.安全性检查算法(1)设置两个工作向量Work=AVAILABLE;FINISH=false;(2)从进程集合中找到一个满足下述条件的进程,FINISH==false;NEED<=Work;如找到,执行(3);否则,执行(4)(3)设进程获得资源,可顺利执行,直至完成,从而释放资源。

Work+=ALLOCATION;Finish=true;(4).如所有的进程Finish= true,则表示安全;否则系统不安全。

3. 银行家算法在避免死锁的方法中,所施加的限制条件较弱,有可能获得令人满意的系统性能。

在该方法中把系统的状态分为安全状态和不安全状态,只要能使系统始终都处于安全状态,便可以避免发生死锁。

银行家算法的基本思想是分配资源之前,判断系统是否是安全的;若是,才分配。

它是最具有代表性的避免死锁的算法。

设进程j提出请求REQUEST [i],则银行家算法按如下规则进行判断。

(1).如果REQUEST [j] [i]<= NEED[j][i],则转(2);否则,出错。

(2).如果REQUEST [j] [i]<= AVAILABLE[j][i],则转(3);否则,出错。

(3).系统试探分配资源,修改相关数据:AVAILABLE[i]-=REQUEST[j][i];ALLOCATION[j][i]+=REQUEST[j][i];NEED[j][i]-=REQUEST[j][i];用到的数据结构:实现银行家算法要有若干数据结构,它们用来表示资源分配系统的状态。

操作系统课程设计--银行家算法

操作系统课程设计--银行家算法

目录第一章功能需求描述 (2)1.1功能列表与说明 (2)1.2操作界面和操作方法 (2)第二章设计描述 (3)2.1任务分解说明 (3)2.2主要数据结构设计说明 (3)2.3主要函数接口设计说明 (3)第三章算法描述 (5)第四章开发过程描述 (14)4.1程序代码 (14)4.2设计中的问题和解决方法 (23)4.3测试用例和测试方法 (24)第五章设计心得体会 (32)计算机科学与技术学院课程设计任务书第一章功能需求描述1.1功能列表与说明(1)添加进程:规定现在操作系统中运行的进程数。

(2)添加资源:规定当前需要资源的种类数和各种类资源的数目。

(3)分配资源:给各进程分配资源。

(4)安全性检查:检查资源分配后是否会发生死锁,若发生则不这样进行分配。

(5)资源释放:当一个进程结束后释放其所占有的各类资源。

(6)得到安全序列:当资源分配能够保证各进程顺利结束,则得到进程的安全序列。

(7)删除资源:即取消某资源1.2操作界面和操作方法*************银行家算法演示****************请首先输入系统可供资源种类的数量:资源*的名称:资源的数量:请输入作业的数量:请输入各进程的最大需求量:请输入各进程已经申请的资源量:系统目前可用资源:系统是否安全?分配的序列:********银行家算法演示***********1:增加资源2:删除资源3:修改资源4:分配资源5:增加作业0:离开在如上的操作界面中分别按照提示进行输入,按回车键表示当前输入完毕,然后进行下个步骤的输入或者得到最终结果。

第二章设计描述2.1任务分解说明银行家算法的实现过程主要分为以下几个部分:为实现银行家算法,系统中必须设置若干数据结构。

其中有allocation,记录已经分配的系统资源;max,记录每个进程的资源最大需求;available,记录剩余资源;need用来记录现在每个进程需要多少资源,need=max-allocation;request 请求资源;temp,记录路径,即输出的顺序;finish,用来实现循环,以判断是否安全,这也就是安全性检查。

银行家算法及流程图

银行家算法及流程图
(2)如果REQUEST [cusneed] [i]<= AVAILABLE[cusneed][i],则转(3);否则,出错。
(3)系统试探分配资源,修改相关数据:
AVAILABLE[i]-=REQUEST[cusneed][i];
ALLOCATION[cusneed][i]+=REQUEST[cusneed][i];
Bank();
}
void Init() /*初始化算法*/

int i,j;
cout〈〈”请输入进程的数目:";
cin〉>m;பைடு நூலகம்
cout〈<"请输入资源的种类:”;
cin〉〉n;
cout<<"请输入每个进程最多所需的各资源数,按照"〈<m<〈"x”<<n〈〈”矩阵输入"〈〈endl;
for(i=0;i<m;i++)
}
for(i=0;i<m;i++)

if(FINISH[i]==true)

continue;

else

for(j=0;j〈n;j++)
{
if(NEED[i][j]>Work[j])
{
break;


if(j==n)

FINISH[i]=true;
for(k=0;k〈n;k++)
{
Work[k]+=ALLOCATION[i][k];
NEED[cusneed][i]-=REQUEST[cusneed][i];

银行家算法流程图+C++源代码+实验报告-课程设计

银行家算法流程图+C++源代码+实验报告-课程设计

银行家算法流程图+C++源代码+实验报告-课程设计银行家算法流程图+C++源代码+实验报告摘要:银行家算法是避免死锁的一种重要方法。

操作系统按照银行家制定的规则为进程分配资源,当进程首次申请资源时,要测试该进程对资源的最大需求量,如果系统现存的资源可以满足它的最大需求量则按当前的申请量分配资源,否则就推迟分配。

当进程在执行中继续申请资源时,先测试该进程已占用的资源数与本次申请的资源数之和是否超过了该进程对资源的最大需求量。

若超过则拒绝分配资源,若没有超过则再测试系统现存的资源能否满足该进程尚需的最大资源量,若能满足则按当前的申请量分配资源,否则也要推迟分配。

银行家算法确实能保证系统时时刻刻都处于安全状态,但它要不断检测每个进程对各类资源的占用和申请情况,需花费较多的时间。

现在的大部分系统都没有采用这个算法,也没有任何关于死锁的检查。

关键字:银行家算法,系统安全,死琐 1,银行家算法原理银行家算法是从当前状态出发,逐个按安全序列检查各客户中谁能完成其工作,然后假定其完成工作且归还全部贷款,再进而检查下一个能完成工作的客户。

如果所有客户都能完成工作,则找到一个安全序列,银行家才是安全的。

缺点:该算法要求客户数保持固定不变,这在多道程序系统中是难以做到的;该算法保证所有客户在有限的时间内得到满足,但实时客户要求快速响应,所以要考虑这个因素;由于要寻找一个安全序列,实际上增加了系统的开销.Banker algorithm 最重要的一点是:保证操作系统的安全状态!这也是操作系统判断是否分配给一个进程资源的标准!那什么是安全状态?举个小例子,进程P 需要申请 8 个资源(假设都是一样的),已经申请了 5 个资源,还差 3 个资源。

若这个时候操作系统还剩下 2 个资源。

很显然,这个时候操作系统无论如何都不能再分配资源给进程 P 了,因为即使全部给了他也不够,还很可能会造成死锁。

若这个时候操作系统还有 3 个资源,无论 P 这一次申请几个资源,操作系统都可以满足他,因为操作系统可以保证 P 不死锁,只要他不把剩余的资源分配给别人,进程 P 就一定能顺利完成任务。

操作系统课程设计-银行家算法(流程图+源代码+设计报告)

操作系统课程设计-银行家算法(流程图+源代码+设计报告)

操作系统课程设计-银行家算法(流程图+源代码+设计报告)一、实验目的:熟悉银行家算法,理解系统产生死锁的原因及避免死锁的方法,加深记意。

二、实验要求:用高级语言编写和调试一个描述银行家算法的程序。

三、实验内容:1、设计一个结构体,用于描述每个进程对资源的要求分配情况。

包括:进程名--name[5],要求资源数目--command[m](m类资源),还需要资源数目--need[m],已分配资源数目--allo[m]。

2、编写三个算法,分别用以完成:①申请资源;②显示资源;③释放资源。

(动态完成)四、程序流程图五、源程序:最新版本:bk5.c/*bk2.c::可以自定义进程及资源数目,可选择读文件或创建新文件,但不超过10,5*//*可修改# define NP 10*//* # define NS 5 */ /*资源种类*//*bk3.c::可以继续分配资源(〉2)*//*bk4.c::可保存分析结果*//*bk5.c::除以上功能外,对暂时不能分配的可以进行另外一次尝试,并恢复已分配的资源*/ /*四、程序流程图:五、源程序:最新版本:bk5.c/*bk2.c::可以自定义进程及资源数目,可选择读文件或创建新文件,但不超过10,5*//*可修改# define NP 10*//* # define NS 5 */ /*资源种类*//*bk3.c::可以继续分配资源(〉2)*//*bk4.c::可保存分析结果*//*bk5.c::除以上功能外,对暂时不能分配的可以进行另外一次尝试,并恢复已分配的资源*/ #include "string.h"#include "stdio.h"#include "dos.h"#include "conio.h"#define MOVEIN 1#define GUIYUE 2#define ACC 3#define OK 1#define ERROR 0#define MAXSH 7#define MAXSHL 10#define MAXINPUT 50#define maxsize 100int act;int ip=0;int line=0; /*line为要写的行号,全局变量*/int writeok;int right;char wel[30] = {"Welcome To Use An_Li System"};char ente[76]={" 警告:未经作者同意不得随意复制更改!"};char rights[40]={"Copyright (c) 2002"};struct date today;struct time now;typedef struct{int data[maxsize];int top;}stack;int emptystack(stack *S){if(S->top==48&&S->data[S->top]==35)return(1); /*35 is '#'*/ else return(0);}int push(stack *S,int x){if(S->top>=maxsize-1)return(-1);else{S->top++;S->data[S->top]=x;return(0);}}int gettop(stack *S){return S->data[S->top];}int pop(stack *S){if(emptystack(S)){printf("the stack is empty\n");exit(1);}else S->top--;return S->data[S->top+1];}void initstack(stack *S){int i;S->top=0;S->data[S->top]=35;}/*****模拟打字机的效果*********/delay_fun(){int i;void music();for(i=0;;i++){if(wel!='\0'){delay(1000);textcolor(YELLOW);gotoxy(26+i,8);cprintf("%c",wel);printf("谢谢");printf("网络 ");music(1,60);}else break;}delay(500000);for(i=0; ; i++){if(ente!='\0'){delay(1000);textcolor(RED);/*显示警告及版权*/ gotoxy(2+i,11);cprintf("%c",ente);music(1,60);}else break;}delay(40000);for(i=0;;i++){if(rights != '\0'){delay(1000);textcolor(YELLOW);gotoxy(30+i,14);cprintf("%c",rights);music(1,60);}elsebreak;}getch();}/*********登陆后的效果**********/logined(){ int i;clrscr();gotoxy(28,10);textcolor(YELLOW);cprintf("程序正在载入请稍候.....");gotoxy(35,12);for(i=0;i<=50;i++){gotoxy(40,12);delay(8000);cprintf("%02d%已完成",i*2);gotoxy(i+15,13);cprintf("\n");cprintf("|");}main0();}/*********对PC扬声器操作的函数****/void music(int loop,int f) /* f为频率*/{ int i;for(i=0;i<30*loop;i++){sound(f*20);delay(200);}nosound();}int analys(int s,int a){int hh,pos;switch(a){case (int)'i':hh=0;break;case (int)'+':hh=1;break;case (int)'*':hh=2;break;case (int)'(':hh=3;break;case (int)')':hh=4;break;case (int)'#':hh=5;break;case (int)'E':hh=6;break;case (int)'T':hh=7;break;case (int)'F':hh=8;break;default:{printf(" \n analys()分析发现不该有的字符 %c !(位置:%d)",a,ip+1); writeerror('0',"\n............分析出现错误!!!");writeerror(a,"\n 错误类型: 不该有字符 ");printf("谢谢");printf("网 ");return ERROR;}}pos=(s-48)*10+hh;switch(pos){case 3:case 43:case 63:case 73:act=4;return MOVEIN;case 0:case 40:case 60:case 70:act=5;return MOVEIN;case 11:case 81: act=6;return MOVEIN;case 92:case 22:act=7;return MOVEIN;case 84:act=11;return MOVEIN;/*-------------------------------------------*/ case 91:case 94:case 95:act=1;return GUIYUE;case 21:case 24:case 25:act=2;return GUIYUE;case 101:case 102:case 104:case 105:act=3;return GUIYUE;case 31:case 32:case 34:case 35:act=4;return GUIYUE;case 111:case 112:case 114:case 115:act=5;return GUIYUE;case 51:case 52:case 54:case 55:act=6;return GUIYUE;/*+++++++++++++++++*/case 15:return ACC;/*******************************/case 6:return 1;case 7:case 47:return 2;case 8:case 48:case 68:return 3;case 46:return 8;case 67:return 9;case 78:return 10;default:{if(a=='#')printf("");else printf(" \n analys() 分析发现字符%c 不是所期望的!(位置:%d)",a,ip+1);writeerror('0',"\n ...........分析出现错误!!!");writeerror(a,"\n 错误类型: 字符 ");writeerror('0'," 不是所期望的! ");printf("谢谢");printf("网 ");return ERROR;}}}int writefile(int a,char *st){FILE *fp;fp=fopen("an_slr.txt","a");if(fp==0){printf("\nwrite error!!");writeok=0;}else{if(a==-1){fprintf(fp," %s ",st); /*若a==-1则为添加的注释*/}else if(a==-2){getdate(&today);gettime(&now);fprintf(fp,"\n 测试日期: %d-%d-%d",today.da_year,today.da_mon,today.da_day); fprintf(fp," 测试时间:%02d:%02d:%02d",now.ti_hour,now.ti_min,now.ti_sec);}else if(a>=0) fprintf(fp,"\n step: %02d , %s",a,st);writeok=1;fclose(fp);}return writeok;}int writeerror(char a,char *st) /*错误类型文件*/{FILE *fpp;fpp=fopen("an_slr.txt","a");if(fpp==0){printf("\nwrite error!!");writeok=0;}else{if(a=='0') fprintf(fpp," %s ",st); /*若a=='0' 则为添加的注释*/else fprintf(fpp," %s \'%c\'(位置:%d) ",st,a,ip+1);writeok=1;fclose(fpp);}return writeok;}/*^^^^^^^^^^^^^^^^^^^^^^*/main0(){int an,flag=1,action,lenr;char a,w[MAXINPUT];int len,s,ss,aa,ana;stack *st;char r[MAXSH][MAXSHL]; /*初始化产生式*/strcpy(r[0],"S->E");strcpy(r[1],"E->E+T");strcpy(r[2],"E->T");strcpy(r[3],"T->T*F");strcpy(r[4],"T->F");strcpy(r[5],"F->(E)");strcpy(r[6],"F->i");clrscr();printf("\nplease input analyse string:\n");gets(w);len=strlen(w);w[len]='#';w[len+1]='\0';initstack(st);push(st,48); /* (int)0 进栈*/writefile(-1,"\n------------------------SLR(1)词法分析器-------------------------");writefile(-1,"\n 计本003 安完成于2003.01.12 14:04");writefile(-1,"\n谢谢");writefile(-1,"网 ");writefile(-1,"\n 以下为串");writefile(-1,w);writefile(-1,"('#'为系统添加)的分析结果: ");writefile(-2," ");do{s=gettop(st);aa=(int)w[ip];action=analys(s,aa);if(action==MOVEIN){ss=48+act;push(st,aa);push(st,ss); /* if ss=4 int =52 */ip++;}else if(action==GUIYUE){lenr=strlen(r[act])-3;for(an=0;an<=2*lenr-1;an++)pop(st); /* #0 */s=gettop(st); /* s=0 */push(st,(int)r[act][0]);/*将产生式左端 F 进栈 */ana=analys(s,(int)r[act][0])+48;if(ana>59)printf("\分析出错:ana>59!!!");push(st,ana);/*analys(s,aa)即为goto(s',aa) */if((line+1)%20==0){printf("\nThis screen is full,press any key to continue!!!");getche();clrscr();}printf(" step %02d: %s\n",line++,r[act]);writefile(line,r[act]);}else if(action==ACC){flag=0;right=1;}else if(action==ERROR){flag=0;right=0;} /*接受成功*/else{flag=0;right=0;} /* 出错*/}while(flag==1);if(right==1)printf("\nok,输入串 %s 为可接受串!!",w);if(right==0)printf("\nsorry,输入串 %s 分析出错!!",w);if(writeok==1){printf("\nAnWin soft have wrote a file an_slr.txt");if(right==1)writefile(-1,"\n最终结果:输入串为可接受串!"); }}main() /*主函数*/{clrscr();delay_fun();logined();}六、测试报告-操作系统课程设计-银行家算法(流程图+源代码+设计报告)六、测试报告:(测试结果保存于系统生成的an.txt 文件中)以下为课本上的实例::-------------------------------------------------------------------------------------========================银行家算法测试结果=========================-------------------------------------------------------------------------------------T0 时刻可用资源(Available) A:3, B:3, C:2测试日期: 2003-6-28 请求分配时间: 14:07:29经测试,可为该进程分配资源。

操作系统课程设计银行家算法

操作系统课程设计银行家算法

课 程 设 计银行家算法2011 年 6 月设计题目学 号 专业班级 学生姓名指导教师课程设计任务书1前言:Dijkstra (1965)提出了一种能够幸免死锁的调度算法,称为银行家算法。

它的模型基于一个小城镇的银行家,他向一群客户别离许诺了必然的贷款额度,每一个客户都有一个贷款额度,银行家明白不可能所有客户同时都需要最大贷款额,因此他只保留必然单位的资金来为客户效劳,而不是知足所有客户贷款需求的最大单位。

那个地址将客户比作进程,贷款比作设备,银行家比作系统。

客户们各自做自己的生意,在某些时刻需要贷款。

在某一时刻,客户已取得的贷款和可用的最大数额贷款称为与资源分派相关的系统状态。

一个状态被称为是平安的,其条件是存在一个状态序列能够使所有的客户均取得其所需的贷款。

若是突然所有的客户都申请,希望取得最大贷款额,而银行家无法知足其中任何一个的要求,那么发生死锁。

不平安状态并非必然致使死锁,因为客户未必需要其最大贷款额度,但银行家不敢抱这种侥幸心理。

银行家算法确实是对每一个请求进行检查,检查若是知足它是不是会致使不平安状态。

假设是,那么不知足该请求;不然便知足。

检查状态是不是平安的方式是看他是不是有足够的资源知足一个距最大需求最近的客户。

若是能够,那么这笔投资以为是能够收回的,然后接着检查下一个距最大需求最近的客户,如此反复下去。

若是所有投资最终都被收回,那么该状态是平安的,最初的请求能够批准。

第一章开题报告(一)该项课程设计的意义;(二)课程设计的任务(三)相关原理及算法描述;(四)开发环境;(五)预期设计目标;1、该项课程设计的意义在多道程序系统中,多个进程的并发执行来改善系统的资源利用率,提高系统的吞吐量,但可能发生一种危险——死锁。

所谓死锁(Deadlock),是指多个进程在运行进程中因争夺资源而造成的一种僵局(DeadlyEmbrace),当进程处于这种状态时,假设无外力作用,他们都无法在向前推动。

银行家算法

银行家算法

衡阳师范学院《计算机操作系统》课程设计题目:银行家算法班级: 1001班学号:10190103作者姓名:付强指导教师: 王玉奇2012年11月16日目录1、课程设计目的及要求 (1)2、概要设计 (1)2.1 银行家算法中的数据结构 (1)2.2 银行家算法 (2)2.3 安全性算法 (2)2.4 程序模块 (3)3、程序流程图 (4)3.1 安全性算法流程图 (4)3.2 银行家算法流程图 (4)4、代码 (6)5、用户手册 (12)5.1运行环境 (12)5.2执行文件 (12)6、运行结果 (12)6.1 运行程序后,显示的界面如下: (12)6.2 输入多组测试数据后得到的后续运行结果 (13)7、总结体会 (15)8、参考文献 (16)1、课程设计目的及要求银行家算法:目的:了解多道程序系统中,多个进程并发执行的资源分配。

设计要求:管理员可以把一定数量的作业供多个用户周转使用,为保证作业的安全管理员规定:当一个用户对作业的最大需求量不超过管理员现有的资金就要接纳该用户;用户可以分期贷款,但贷款的总数不能超过最大需求量;当管理员现有的作业不能满足用户的所需数时,对用户的请求可推迟支付,但总能使用户在有限的时间里得到请求;当用户得到所需的全部作业后,一定能在有限的时间里归还所有的作业。

2、概要设计2.1 银行家算法中的数据结构(1)可利用资源向量available这是一个含有m个元素的数组,其中的每一个元素代表一类可利用的资源数目,其初始值是系统中所配置的该类全部可用资源的数目,其数值随该类资源的分配和回收而动态地改变。

available[j]=k,表示系统中现有Rj类资源k个。

(2)最大需求矩阵max[n][m]这是一个n×m的矩阵,它定义了系统中n个进程中的每一个进程对m类资源的最大需求。

max[i][j]=k,表示进程i需要Rj类资源的最大数目为k。

(3)分配矩阵allocation[n][m]这也是一个n×m的矩阵,它定义了系统中每一类资源当前分配给每一进程的资源数,如果allocatioon[i][j]=k,则表示进程i当前已分得Rj类资源的数目为k。

深入解析银行家算法

深入解析银行家算法

深入解析银行家算法银行家算法是一种用于多进程系统的资源分配和调度算法,目的是确保系统中的各个进程能够安全地访问所需的资源,且不会发生死锁(Deadlock)的情况。

本文将深入解析银行家算法的工作原理和应用。

1. 背景和定义:银行家算法最初由Dijkstra提出,用于解决多进程系统中资源分配的问题。

它基于银行家和客户的关系类比,将系统中的资源视为银行家的资金,将进程视为客户。

银行家必须合理分配资金,以避免资金不足导致系统中的进程无法完成任务。

2. 原理:银行家算法运用了安全性检查(safety check)和资源分配策略。

安全性检查是通过模拟资源分配的情况,判断系统是否处于安全状态,即不存在死锁,可以继续分配资源。

资源分配策略是根据安全性检查的结果,将资源分配给请求资源的进程,确保系统安全性。

3. 数据结构:银行家算法使用以下数据结构:进程的最大需求矩阵(Maximum),系统已分配资源矩阵(Allocation),系统可用资源向量(Available),进程的尚需资源矩阵(Need)。

这些数据结构可以反映每个进程对每种资源的需求量、已分配量和尚需量。

4. 算法流程:银行家算法的流程如下:- 系统初始化:将每个进程的最大需求矩阵、已分配资源矩阵和系统可用资源向量初始化。

- 请求资源:当某个进程请求资源时,首先检查该请求是否超出了其最大需求量和系统可用资源量,如果超出则拒绝请求;否则进入下一步。

- 模拟分配:假设分配资源给该进程,更新进程的已分配资源矩阵和系统可用资源向量。

- 安全性检查:检查系统是否处于安全状态,即不存在死锁。

该检查基于银行家算法的安全性条件,即每个进程的尚需资源量可以得到满足。

- 分配或回滚:如果安全性检查通过,则进程得到资源分配,否则回滚分配过程,恢复之前的状态。

5. 应用场景:银行家算法广泛应用于操作系统中,尤其是在多任务和多进程环境下。

它可以帮助确定是否可以分配资源给某个进程,以避免资源竞争和死锁的问题。

操作系统实验之银行家算法

操作系统实验之银行家算法

操作系统实验之银行家算法操作系统实验——银行家算法一、实验目的1、理解银行家算法。

2、掌握进程安全性检查的方法与资源分配的方法。

二、实验内容与基本要求编制模拟银行家算法的程序,并以下面给出的例子验证所编写的程序的正确性。

现在系统中A、B、C、D 4类资源分别还剩1、5、2、0个,请按银行家算法回答:1、现在系统是否处于安全状态?2、如果现在进程P1提出需要0、4、2、0个资源的请求,系统能否满足它的请求?三、实验报告内容1、银行家算法和安全性检查算法原理银行家算法:银行家算法最初级原为银行系统设计,以确保银行在发放现金贷款时,不会发生不能满足所有客户需要的情况。

在OS设计中,也可以用它来避免死锁。

为实现银行家算法,每个新进程在进入系统时它必须申明在运行过程中,可能需要的每种资源类型的最大单元数目,其数目不应超过系统所拥有的资源总量。

当某一进程请求时,系统会自动判断请求量是否小于进程最大所需,同时判断请求量是否小于当前系统资源剩余量。

若两项均满足,则系统试分配资源并执行安全性检查算法。

安全性检查算法 :安全性检查算法用于检查系统进行资源分配后是否安全,若安全系统才可以执行此次分配;若不安全,则系统不执行此次分配。

安全性检查算法原理为:在系统试分配资源后,算法从现有进程列表寻找出一个可执行的进程进行执行,执行完成后回收进程占用资源;进而寻找下一个可执行进程。

当进程需求量大于系统可分配量时,进程无法执行。

当所有进程均可执行,则产生一个安全执行序列,系统资源分配成功。

若进程无法全部执行,即无法找到一条安全序列,则说明系统在分配资源后会不安全,所以此次分配失败。

2、程序流程图3、程序及注释#include////////////////////////////////////////////////////////////////////////// //全局变量定义int Available[100]; //可利用资源数组int Max[50][100]; //最大需求矩阵int Allocation[50][100]; //分配矩阵int Need[50][100]; //需求矩阵int Request[50][100]; //M个进程还需要N类资源的资源量int Finish[50];int p[50];int m,n; //M个进程,N类资源///////////////////////////////////////////////////////////////////////// //安全性算法int Safe{int i,j,l=0;int Work[100]; //可利用资源数组for i=0;iWork[i]=Available[i];for i=0;iFinish[i]=0;for i=0;i{if Finish[i]==1continue;else{for j=0;j{if Need[i][j]>Work[j]break;}if j==n{Finish[i]=1;forint k=0;kWork[k]+=Allocation[i][k]; p[l++]=i;i=-1;}else continue;}if l==m{cout<<"系统是安全的"<<'\n'; cout<<"系统安全序列是:\n"; for i=0;i{cout<if i!=l-1cout<<"-->";}cout<<'\n';return 1;}}}////////////////////////////////////////////////////////////////////////////// /////银行家算法int main{int i,j,mi;cout<<"输入进程的数目:\n";cin>>m;cout<<"输入资源的种类:\n";cin>>n;cout<<"输入每个进程最多所需的各类资源数,按照"<for i=0;iforj=0;jcin>>Max[i][j];cout<<"输入每个进程已经分配的各类资源数,按照"<for i=0;i{forj=0;j{cin>>Allocation[i][j];Need[i][j]=Max[i][j]-Allocation[i][j];if Need[i][j]<0{cout<<"你输入的第"<j--;continue;}}}cout<<"请输入各个资源现有的数目:\n";for i=0;icin>>Available[i];Safe;while 1{cout<<"输入要申请的资源的进程号:第一个进程号为0,第二个进程号为1,依此类推\n";cin>>mi;cout<<"输入进程所请求的各个资源的数量\n";for i=0;icin>>Request[mi][i];for i=0;i{if Request[mi][i]>Need[mi][i]{cout<<"所请求资源数超过进程的需求量!\n";return 0;}if Request[mi][i]>Available[i]{cout<<"所请求资源数超过系统所有的资源数!\n"; return 0;}}for i=0;i{Available[i]-=Request[mi][i];Allocation[mi][i]+=Request[mi][i];Need[mi][i]-=Request[mi][i];}if Safecout<<"同意分配请求\n";else{cout<<"SORRY╮╯▽╰╭……你的请求被拒绝…\n"; for i=0;iAvailable[i]+=Request[mi][i];Allocation[mi][i]-=Request[mi][i];Need[mi][i]+=Request[mi][i];}}for i=0;iFinish[i]=0;char Flag; //标志位cout<<"是否再次请求分配?是请按Y/y,否请按N/n"; while 1{cin>>Flag;if Flag=='Y'||Flag=='y'||Flag=='N'||Flag=='n' break;else{cout<<"请按要求重新输入:\n";continue;}}if Flag=='Y'||Flag=='y'continue;else break;}4、运行结果以及结论图示为题目所给定的条件下的程序运行结果。

银行家算法报告

银行家算法报告

银行家算法报告课程设计报告题 目 银行家算法程序设计课 程 名 称 操作系统课程设计 院 部 名 称 信息技术学院 专 业 计算机科学与技术 班 级 。

学 生 姓 名 。

学 号 。

课程设计地点 。

课程设计学时 20 指 导 教 师 。

金陵科技学院教务处制 成绩引言Dijkstra (1965)提出了一种能够避免死锁的调度算法,称为银行家算法。

它的模型基于一个小城镇的银行家,他向一群客户分别承诺了一定的贷款额度,每个客户都有一个贷款额度,银行家知道不可能所有客户同时都需要最大贷款额,所以他只保留一定单位的资金来为客户服务,而不是满足所有客户贷款需求的最大单位。

这里将客户比作进程,贷款比作设备,银行家比作系统。

客户们各自做自己的生意,在某些时刻需要贷款。

在某一时刻,客户已获得的贷款和可用的最大数额贷款称为与资源分配相关的系统状态。

一个状态被称为是安全的,其条件是存在一个状态序列能够使所有的客户均得到其所需的贷款。

如果忽然所有的客户都申请,希望得到最大贷款额,而银行家无法满足其中任何一个的要求,则发生死锁。

不安全状态并不一定导致死锁,因为客户未必需要其最大贷款额度,但银行家不敢抱这种侥幸心理。

银行家算法就是对每一个请求进行检查,检查如果满足它是否会导致不安全状态。

若是,则不满足该请求;否则便满足。

检查状态是否安全的方法是看他是否有足够的资源满足一个距最大需求最近的客户。

如果可以,则这笔投资认为是能够收回的,然后接着检查下一个距最大需求最近的客户,如此反复下去。

如果所有投资最终都被收回,则该状态是安全的,最初的请求可以批准。

在预防死锁的几种方法之中,都施加了较强的限制条件;而在避免死锁的方法中,所施加的限制条件较弱,有可能获得令人满意的系统性能。

在该方法中把系统状态分为安全状态和不安全状态,便可避免死锁的发生。

而最具代表性的避免死锁的算法,便是Dijkstra的银行家算法。

利用银行家算法,我们可以来检测CPU为进程分配资源的情况,决定CPU是否响应某进程的的请求并为其分配资源,从而很好避免了死锁1、课程设计的目的和要求目的:银行家算法是避免死锁的一种重要方法,本设计要求用C语言(或高级语言)编写和调试一个简单的银行家算法程序。

银行家算法

银行家算法

2
5 5 4 4
1
0 0 2 1
3
0 2 1
4
6 0 1 0
P4 P5 P1 P2
P3
(3)在T0时刻P4请求[2,0,1]能否实施分配?为什么?
在T0时刻系统剩余资源为[2,3,3]大于P4的剩余最大需求 [2,2,1] , 且 P4 现 在 请 求 [2,0,1] 加 上 T0 时 刻 前 已 分 配 [2,0,4]也没有超过其最大需求max[4,2,5],因此系统可以
请资源,系统在进行资源分配之前,先计
算资源分配的安全性。若此次分配不会导
致系统进入不安全状态,便将资源分配给
进程;否则进程等待。
操 作 系 统 分 配 资 源 过 程 示 意 图
进程P首次请求分配k个资源 系统现存资源>=进程 P对资源最大需求m? 是 给进程P分配k个资源 推迟分配 否
进程P又请求分配h个资源
available A BP5
4
4
2
2
5
4
2
3 15
0
1
4
4
2
1
2
1
1
0
2 17
(1)T0时刻是否为安全状态?若是则
给出安全序列。
资源总数:[17,5,20]
进程
A P1 5 max B 5 C 9 allocation A 2 B 1 C 2 A 3 need B 4 C 7
1: <P4,P5,P1,P2,P3> 2: <P4,P5,P1,P3,P2> 3: <P4,P5,P2,P1,P3> 4: <P4,P5,P2,P3,P1> 5: <P4,P5,P2,P3,P1> 6: <P4,P5,P3,P2,P1> 7: <P4,P2,P3,P5,P1> 8: <P4,P2,P5,P3,P1> 9: <P4,P2,P5,P1,P3> 10:<P4,P3,P2,P5,P1> 11:<P4,P3,P5,P1,P2> 12:<P4,P3,P5,P2,P1>

操作系统课程设计报告—银行家算法

操作系统课程设计报告—银行家算法

操作系统课程设计报告题目:银行家算法院(系):专业:班级:学生:学号:指导教师:操作系统课程设计报告摘要Dijkstra提出的银行家算法,是最具代表性的避免死锁的算法。

本文对如何用银行家算法来处理操作系统给进程分配资源做了详细的说明,包括需求分析、概要设计、详细设计、测试与分析、总结、源程序清单。

首先做了需求分析,解释了什么是银行家算法,并指出它在资源分配中的重要作用。

然后给出了银行家算法的概要设计,包括算法思路、步骤,以及要用到的主要数据结构、函数模块及其之间的调用关系等。

在概要设计的基础上,又给出了详细的算法设计,实现概要设计中定义的所有函数,对每个函数写出核心算法,并画出了流程图。

接着对编码进行了测试与分析(并在最后附上Java编写的程序代码)。

最后对整个设计过程进行了总结。

关键词:安全状态;安全序列;银行家算法;安全性算法;安全序列;流程图。

目录摘要 (1)1绪论 (4)1.1前言 (5)1.2研究意义 (5)1.3结构安排 (5)2需求分析 (4)2.1题目描述 (5)2.2银行家算法 (5)2.3基本要求 (5)2.4目的 (5)3概要设计 (4)3.1基本思路 (5)3.2银行家算法步骤 (5)3.3安全型算法步骤 (5)3.4数据结构 (5)3.4.1主要用到的数据结构 (6)3.4.2程序模块 (6)3.4.3各模块间的调用关系 (6)4详细设计 (4)4.1主要函数的核心代码 (5)4.1程序流程图 (5)5测试 (4)5.1测试用例 (5)5.1测试结果分析和截图 (5)6总结 (4)参考文献 (4)附录:原程序清单 (4)1绪论1.1前言:Dijkstra (1965)提出了一种能够避免死锁的调度算法,称为银行家算法。

它的模型基于一个小城镇的银行家,他向一群客户分别承诺了一定的贷款额度,每个客户都有一个贷款额度,银行家知道不可能所有客户同时都需要最大贷款额,所以他只保留一定单位的资金来为客户服务,而不是满足所有客户贷款需求的最大单位。

实验二银行家算法

实验二银行家算法

实验二银行家算法一、目的:加深了解有关资源申请、避免死锁等概念,并体会和了解死锁和避免死锁的具体实施方法。

要求编写和调试一个系统动态分配资源的简单模拟程序,观察死锁产生的条件,并采用银行家算法,有效地防止和避免死锁的发生。

二、内容:银行家算法是避免死锁的一种重要方法,本实验要求编写和调试一个简单的银行家算法程序。

用银行家算法实现资源分配。

三、编程思想:首先分析银行家算法的数据结构,分析可利用资源向量Available、最大需求矩阵Max、分配矩阵Allocation、需求矩阵Need 、进程申请资源的关系,由所学知识可知;Need[i,j]=Max[I,j]-Allocation[i,j];当进程申请资源的时候;a)Requesti>Need[i]。

这种情况表示该进程的资源需求已超过系统所宣布的最大值,出错。

b)Requesti=Need[i]。

这种情况表示该进程现在对他所需的全部资源一次申请完成。

c)Requesti〉Need[i]。

这种情况表示该进程现在对它所需资源再进行部分的申请,剩余的资源以后再次申请。

当进程pi发出资源请求后;a)如果Requesti<=Need[i],转向步骤b,否则显示为出错,因为所需的资源数超过事先要求的最大值。

b)Requesti <=Available,便转向步骤三,否则则表示尚无足够资源,pi需等待。

c)假如系统将资源分配给pi则:Available=Available-RequestiAllocation[i]=Allocation[i]+RequestiNeed[i]=Need[i]-Request安全性算法检查(1)设置向量:工作向量Work,它表示系统可提供给进程继续运行所需的各类资源数目,在执行安全性算法开始时,Work[]= Available[]。

Finish[],它表示系统是否有足够的资源分配给每个进程,使之运行完成。

开始时先做Finish[i]=0;当有足够的资源分配给进程时,再令Finish[i]=1。

实验3 银行家算法

实验3 银行家算法

实验三银行家算法一、实验目的模拟银行家算法,用银行家算法实现资源分配二、实验内容写程序用银行家算法判断系统能否将资源分配给它;(2)若进程P2提出请求Request(0,1,0),用银行家算法程序验证系统能否将资源分配给它。

#include<stdio.h>#include<string.h>#define RESOURCE 3#define PRO 5class Process{public :int max[RESOURCE];int allocation[RESOURCE];int need[RESOURCE];int request[RESOURCE];//对资源第一次分配void Inital(int index,int allo,int n){allocation[index] = allo;need[index] = n;}//某个进程需要资源void Request(int index,int req){request[index] = req;}};//检测安全性bool Safe(int work[],Process pro[]){bool finish[PRO];for(int i=0;i<PRO;i++){finish[i] =false;}int j=0; //用来表示资源下标int k=0;int index[PRO];for(i=0;i<PRO-1;i++){for(int m=0;m<PRO;m++){if(work[j] >= pro[m].need[j] && work[j+1] >= pro[m].need[j+1]&& work[j+2] >= pro[m].need[j+2] && finish[m] == false){finish[m] = true;index[k++] = m;for(int j=0;j<RESOURCE;j++){work[j] = work[j] + pro[m].allocation[j];}}}for(i=0;i<PRO;i++){if(finish[i] ==false){printf("该申请资源数量不合法,不存在安全序列~\n");return false;}}printf("该进程申请的资源数量合法,其安全序列为:\n{");for(i=0;i<PRO;i++){{printf(" p%d;",index[i]);}}printf("}\n");return true;}//用来比较所申请的资源是否满足要求bool Compare(int index,int avaliable[],Process pro[]){for(int i=0;i<RESOURCE;i++){if(pro[index].need[i] < pro[index].request[i] || avaliable[i] < pro[index].request[i])return false;}return true;}//void Require(int index, bool check,int avaliable[], Process pro[]){if(check == false){printf("第一次分配资源造成死锁,不合理。

操作系统 银行家算法

操作系统  银行家算法

实验报告课程名称:操作系统Array实验项目名称:银行家算法实验时间:3月21日班级:计算091 姓名:祖健铭学号: 910402152实验目的:1.理解死锁避免相关内容;2.掌握银行家算法主要流程;3.掌握安全性检查流程。

实验环境:硬件:PC机WindowXP的系统操作软件:安装了WIN-TC帮助实现程序实验内容及过程:死锁避免定义:在系统运行过程中,对进程发出的每一个资源申请进行动态检查,并根据检查结果决定是否分配资源:若分配后系统可能发生死锁,则不予分配,否则予以分配。

由于在避免死锁的策略中,允许进程动态地申请资源。

因而,系统在进行资源分配之前预先计算资源分配的安全性。

若此次分配不会导致系统进入不安全状态,则将资源分配给进程;否则,进程等待。

其中最具有代表性的避免死锁算法是银行家算法。

系统安全状态所谓系统是安全的,是指系统中的所有进程能够按照某一种次序分配资源,并且依次地运行完毕,这种进程序列{ P1 ,P2 …Pn}就是安全序列。

如果存在这样一个安全序列,则系统是安全的。

并非所有的不安全状态都会转为死锁状态,但当系统进入不安全状态后,便有可能进入死锁状态;反之,只要系统处于安全状态,系统便可避免进入死锁状态。

所以避免死锁的实质:系统在进行资源分配时,如何使系统不进入不安全状态。

银行家算法中的数据结构①可利用资源向量Available。

这是一个含有m个元素的数组,其中的每一个元素代表一类可利用的资源数目,其初始值是系统中所配置的该类全部可用资源的数目,其数值随该类资源的分配和回收而动态地改变。

如果Available[j]=K,则表示系统中现有Rj类资源K个。

②最大需求矩阵Max。

最大需求矩阵Max。

这是一个n×m的矩阵,它定义了系统中n个进程中的每一个进程对m类资源的最大需求。

如果Max[i,j]=K,则表示进程i需要Rj类资源的最大数目为K。

③分配矩阵Allocation这也是一个n×m的矩阵,它定义了系统中每一类资源当前已分配给每一进程的资源数。

银行家算法c++语言(流程图代码全)

银行家算法c++语言(流程图代码全)

操作系统教程——银行家算法院系计算机与软件学院班级08软件工程2班学号20081344066姓名何丽茗一、实验目的银行家算法是避免死锁的一种重要方法。

通过编写一个模拟动态资源分配的银行家算法程序,进一步深入理解死锁、产生死锁的必要条件、安全状态等重要概念,并掌握避免死锁的具体实施方法。

二、实验内容根据银行家算法的基本思想,编写和调试一个实现动态资源分配的模拟程序,并能够有效地防止和避免死锁的发生。

三、实验方法1.算法流程图2.算法数据结构1)可利用资源向量Available ,它是一个最多含有100个元素的数组,其中的每一个元素代表一类可利用的资源的数目,其初始值是系统中所配置的该类全部可用资源数目。

其数值随该类资源的分配和回收而动态地改变。

如果Available(j)=k,标是系统中现有j 类资源k个。

2)最大需求矩阵Max,这是一个n×m的矩阵,它定义了系统中n个进程中的每一个进程对m类资源的最大需求。

如果Max(i,j)=k,表示进程i需要j类资源的最大数目为k。

3)分配矩阵Allocation,这也是一个n×m的矩阵,它定义了系统中的每类资源当前一分配到每一个进程的资源数。

如果Allocation(i,j)=k,表示进程i当前已经分到j类资源的数目为k。

Allocation i表示进程i的分配向量,有矩阵Allocation的第i行构成。

4)需求矩阵Need,这还是一个n×m的矩阵,用以表示每个进程还需要的各类资源的数目。

如果Need(i,j)=k,表示进程i还需要j类资源k个,才能完成其任务。

Need i 表示进程i的需求向量,由矩阵Need的第i行构成。

5)上述三个矩阵间存在关系:Need(i,j)=Max(i,j)-Allocation(i,j);3.银行家算法设Request[i] 是进程i的请求向量,如果Request[i,j]=K,表示进程i需要K个j类型的资源。

银行家算法简要概述

银行家算法简要概述

一.需求分析⏹银行模拟系统要求模拟银行一天0~closetime的营业情况,业务总共分为两类。

存款与取款。

开始银行拥有一定数量的总额total供运行。

程序运行输出银行在处理业务后的事件表。

包括时间,存款数量,取款数量,银行余額,等待情况。

⏹程序输入的形式是按以下顺序输入到屏幕中,只需按照提示操作即可:银行总余額–>银行运行时间->交易时间上、下界->事件时间上、下界->客户存取金额⏹程序输出的形式是按照时间顺序输出银行运行期间的事件表⏹程序的功能是模拟显示银行在整个营业阶段的运行状况二.概要设计本程序中用到的抽象数据类型有伪随机数类random,队列类bankqueue,客户类client伪随机数类random的定义如下:class random{public:random();//空构造函数random(unsigned short initialSeed);//带参构造unsigned short randomInterger();//种子seed产生函数double rabdomDouble();//双精度数产生函数double between(double low ,double high);//围随机数产生函数(double 型)int between(int low,int high);//围随机数产生函数(int型)private:unsigned short seed;};客户类client的定义如下:class Client{public:int num;int money;Client *next;int Dealingtime;int Casetime;};客户队列bankqueue定义如下:class bankqueue{public:int n;bankqueue();//构造~bankqueue();//析构void enqueue(Client * c);//进队列Client* dequeue();//出队列int isEmpty();//判断空否void deleteALLValues();//删除所有元素private:Client *front,*tail;};本程序利用队列结果储存客户信息:三. 详细设计随机数类实现:●随机数类构造 {种子=时钟; }●返回短整数的函数 {乘数=33339;加数=759812;种子=(乘数*种子+加数)%31637687;返回种子; }●在low 和high 之间产生整型随机数{调用返回短整数的函数+low;}银行节点和队列类实现:●银行队列构造函数{前指针=0;尾指针=0;长度=0;}●析构函数{};进队列函数(银行节点指针){节点指针数据复制到新节点指针数据如果队列空{前指针=0;尾指针=0}尾指针=0;长度+1;}出队列{新建指针P头指针向前走查看队列是否为空返回指针P}●判断队列是否为空{返回头指针是否为0;}删除所有元素{长度,尾指针置0;从队列里弹出节点并删除}四.调试分析➢银行模拟系统调试过程中遇到的问题:由于要运用到文件输入输出流,无法访问Bank类的私有数据,故将大部分程序写入Main函数中经验和体会等:从写完代码到调试成功,最后不断的改进和完善,不仅巩固了类定义和实现,还极大的挑战了我们编程能力。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
}
if(Safe())
{
cout<<"同意分配请求!"<<endl;
}
else
{
cout<<"您的请求被拒绝!"<<endl;
for(i=0;i<n;i++)
{
AVAILABLE[i]+=REQUEST[cusneed][i];
ALLOCATION[cusneed][i]-=REQUEST[cusneed][i];
}
p[l++]=i;
i=-1;
}
else
{
continue;
}
}
if(l==m)
{
cout<<"系统是安全的"<<endl;
cout<<"安全序列:"<<endl;
for(i=0;i<l;i++)
{
cout<<p[i];
if(i!=l-1)
{
cout<<"-->";
}
}
cout<<""<<endl;
Bank();
}
void Init() /*初始化算法*/
{
int i,j;
cout<<"请输入进程的数目:";
cin>>m;
cout<<"请输入资源的种类:";
cin>>n;
cout<<"请输入每个进程最多所需的各资源数,按照"<<m<<"x"<<n<<"矩阵输入"<<endl;
for(i=0;i<m;i++)
银行家算法及流程图
算法的实现
一、初始化
由用户输入数据,分别对可利用资源向量矩阵AVAILABLE、最大需求矩阵MAX、分配矩阵ALLOCATION、需求矩阵NEED赋值。
二、银行家算法
在避免死锁的方法中,所施加的限制条件较弱,有可能获得令人满意的系统性能。在该方法中把系统的状态分为安全状态和不安全状态,只要能使系统始终都处于安全状态,便可以避免发生死锁。
}
for(i=0;i<m;i++)
{
if(FINISH[i]==true)
{
continue;
}
else
{
for(j=0;j<n;j++)
{
if(NEED[i][j]>Work[j])
{
break;
}
}
if(j==n)
{
FINISH[i]=true;
for(k=0;k<n;k++)
{
Work[k]+=ALLOCATION[i][k];
{
cout<<"您输入的请求数超过系统有的资源数!请重新输入!"<<endl;
continue;
}
}
for(i=0;i<n;i++)
{
AVAILABLE[i]-=REQUEST[cusneed][i];
ALLOCATION[cusneed][i]+=REQUEST[cusneed][i];
NEED[cusneed][i]-=REQUEST[cusneed][i];
bool FINISH[MAXPROCESS]; /*系统是否有足够的资源分配*/
int p[MAXPROCESS]; /*记录序列*/
int m,n; /*m个进程,n个资源*/
void Init();
bool Safe();
void Bank();
int main()
{
Init();
Safe();
return true;
}
}
cout<<"系统是不安全的"<<endl;
return false;
}
NEED[cusneed][i]-=REQUEST[cusneed][i];
(4)系统执行安全性检查,如安全,则分配成立;否则试探险性分配作废,系统恢复原状,进程等待。
三、安全性检查算法
(1)设置两个工作向量Work=AVAILABLE;FINISH
(2)从进程集合中找到一个满足下述条件的进程,
FINISH==false;
{
cin>>REQUEST[cusneed][i];
}
for(i=0;i<n;i++)
{
if(REQUEST[cusneed][i]>NEED[cusneed][i])
{
cout<<"您输入的请求数超过进程的需求量!请重新输入!"<<endl;
continue;
}
if(REQUEST[cusneed][i]>AVAILABLE[i])
安全性算法流程图:
源程序清单
#include <iostream>
using namespace std;
#define MAXPROCESS 50 /*最大进程数*/
#define MAXRESOURCE 100 /*最大资源数*/
int AVAILABLE[MAXRESOURCE]; /*可用资源数组*/
NEED[eed][i];
}
}
for(i=0;i<m;i++)
{
FINISH[i]=false;
}
cout<<"您还想再次请求分配吗?是请按y/Y,否请按其它键"<<endl;
cin>>again;
if(again=='y'||again=='Y')
NEED<=Work;
如找到,执行(3);否则,执行(4)
(3)设进程获得资源,可顺利执行,直至完成,从而释放资源。
Work+=ALLOCATION;
Finish=true;
GOTO 2
(4)如所有的进程Finish= true,则表示安全;否则系统不安全。
各算法流程图
初始化算法流程图:
银行家算法流程图:
int MAX[MAXPROCESS][MAXRESOURCE]; /*最大需求矩阵*/
int ALLOCATION[MAXPROCESS][MAXRESOURCE]; /*分配矩阵*/
int NEED[MAXPROCESS][MAXRESOURCE]; /*需求矩阵*/
int REQUEST[MAXPROCESS][MAXRESOURCE]; /*进程需要资源数*/
(2)如果REQUEST [cusneed] [i]<= AVAILABLE[cusneed][i],则转(3);否则,出错。
(3)系统试探分配资源,修改相关数据:
AVAILABLE[i]-=REQUEST[cusneed][i];
ALLOCATION[cusneed][i]+=REQUEST[cusneed][i];
if(NEED[i][j]<0)
{
cout<<"您输入的第"<<i+1<<"个进程所拥有的第"<<j+1<<"个资源数错误,请重新输入:"<<endl;
j--;
continue;
}
}
}
cout<<"请输入各个资源现有的数目:"<<endl;
for(i=0;i<n;i++)
{
cin>>AVAILABLE[i];
{
continue;
}
break;
}
}
bool Safe() /*安全性算法*/
{
int i,j,k,l=0;
int Work[MAXRESOURCE]; /*工作数组*/
for(i=0;i<n;i++)
Work[i]=AVAILABLE[i];
for(i=0;i<m;i++)
{
FINISH[i]=false;
银行家算法的基本思想是分配资源之前,判断系统是否是安全的;若是,才分配。它是最具有代表性的避免死锁的算法。
设进程cusneed提出请求REQUEST [i],则银行家算法按如下规则进行判断。
(1)如果REQUEST [cusneed] [i]<= NEED[cusneed][i],则转(2);否则,出错。
for(j=0;j<n;j++)
cin>>MAX[i][j];
cout<<"请输入每个进程已分配的各资源数,也按照"<<m<<"x"<<n<<"矩阵输入"<<endl;
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
cin>>ALLOCATION[i][j];
相关文档
最新文档