银行家算法实验报告
银行家算法实验报告总结
银行家算法实验报告总结一、实验目的与背景银行家算法是一种用于避免死锁和保证系统稳定运行的算法。
通过模拟银行贷款行为的策略,银行家算法可以有效地避免系统的资源枯竭,从而保证系统的正常运行。
在本实验中,我们通过使用银行家算法对实际的系统进行模拟,验证其有效性。
二、算法原理与流程银行家算法的主要原理是:将系统中的所有资源按照类型进行分类,并对每种资源设置一个最大值和最小值,分别表示该资源的最大需求量和最小剩余量。
同时,对于每个进程,需要定义其最大需求量、已分配资源和需求量,并根据这些信息来决定是否分配资源。
具体流程如下:初始化:将所有资源的最大值和最小值进行初始化,并给每个进程分配一个唯一的标识符。
请求资源:每个进程在执行过程中,如果需要更多的资源,则向系统发送请求。
分配资源:系统根据银行家算法的原理,将资源分配给满足条件的进程。
更新资源:系统更新已分配给进程的资源,并检查是否满足每个进程的最大需求量。
重复执行:如果存在多个进程需要资源,则重复执行步骤2-4,直到所有进程都满足其最大需求量或系统中的资源不足以为更多的进程分配资源为止。
三、实验数据与结果在本实验中,我们使用了10个进程,每个进程的需求量和已分配资源均随机生成。
实验结果表明,在满足了每个进程的最大需求量后,系统中仍有剩余资源,证明了银行家算法可以有效地避免资源的浪费。
四、结果分析通过对实验结果进行分析,我们发现银行家算法可以有效地保证系统的稳定性,避免出现死锁和资源枯竭等问题。
同时,该算法需要较少的系统开销,因为只需要对每个进程的请求进行处理和更新,不需要进行额外的检查和管理。
五、性能对比分析为了进一步验证银行家算法的性能,我们将其与其他常见的资源管理算法进行了比较。
在同等条件下,与其他算法相比,银行家算法具有更高的系统吞吐量和更低的响应时间。
银行家算法在系统吞吐量和响应时间方面均优于其他常见算法,而在死锁发生率上,银行家算法则表现出了更高的稳定性。
银行家算法实验报告
银行家算法实验报告银行家算法实验报告引言:在计算机科学领域中,银行家算法是一种用于避免死锁的资源分配算法。
它是由荷兰计算机科学家艾兹赫尔·迪科斯彻在1965年提出的。
银行家算法通过合理的资源分配和安全性检查,确保系统中的进程能够安全地执行,避免了资源竞争和死锁的发生。
本篇文章将详细介绍银行家算法的原理、实验设计和结果分析。
一、银行家算法的原理银行家算法基于资源的最大需求和可用性进行资源分配。
它将系统中的资源分为若干类别,并为每个类别分配一个初始数量。
当进程请求资源时,银行家算法会检查该请求是否能够满足,如果满足则分配资源,否则将进程置于等待状态。
算法的核心思想是避免分配资源后导致系统无法满足其他进程的资源需求,从而避免死锁的发生。
二、实验设计为了验证银行家算法的有效性,我们设计了一个模拟实验。
实验中,我们创建了一个包含多个进程和资源的系统,并模拟了进程对资源的请求和释放。
每个进程都有自己的资源需求和最大需求量,系统中的资源总量也是有限的。
首先,我们初始化系统的资源数量和每个进程的最大需求量。
然后,模拟进程的请求和释放过程。
当一个进程请求资源时,银行家算法会检查该请求是否能够满足,如果满足则分配资源,否则将进程置于等待状态。
当一个进程释放资源时,系统将回收该资源并重新分配给其他进程。
实验的关键是设计合理的资源分配策略和进程请求顺序,以模拟不同的场景。
我们通过调整进程的最大需求量和资源数量,观察系统的运行情况和死锁的发生情况。
三、实验结果分析通过多次实验,我们得出了以下结论:1. 资源数量的合理分配对避免死锁非常重要。
如果资源数量过少,无法满足进程的最大需求量,系统容易发生死锁。
如果资源数量过多,系统的资源利用率低,效率低下。
因此,需要根据系统的实际需求合理分配资源数量。
2. 进程的最大需求量与资源数量的关系也是影响死锁的重要因素。
当进程的最大需求量超过系统资源数量的一半时,系统容易发生死锁。
银行家算法实验报告
银行家算法实验报告银行家算法是为了实现避免出现死锁的状态而采取的一种算法,本实验则是用C语言实现。
一、银行家算法数据结构1、可利用资源数量Avail。
这是一个含M个元素的数组,其中每一个元素代表一类可用的资源数目,定义为int型,Avail[m]。
2、最大需求矩阵Max。
这是一个nxm的二维矩阵,它定义了系统中n个进程的每一个进程对m类资源的最大需求,定义为int型,Max[n][m]。
3、分配矩阵Alloc。
这是一个nxm的二维矩阵,它定义了系统中每一类资源当前已分配给每一进程的资源数。
定义为int型,Alloc[n][m]。
4、需求矩阵Need。
这也是一个nxm的二维矩阵,用以表示每一个进程尚需的各类资源数。
定义为int型,Need[n][m]。
5、请求资源数目Request。
这是一个含M个元素的数组,它表示进程请求的资源数目,定义为int型,Request[m]。
6、系统当前可用的资源矩阵Work,这是一个含M个元素的数组,表示系统还可以分配的资源数目,用于对安全算法的检测。
定义为int型,Work[m]。
7、记录安全序号的数组sequence,用于记录系统的安全信号,便于在后面输出。
定义为int型,sequence[n].二、银行家算法过程步骤如下:1、判断请求的资源是否超过他所宣布需要的最大值,即如果request[j]>need[i][j],则判断出错,否则继续执行。
2、判断请求的资源是否超过系统可分配的数目,即如果request[j]>Avail[j],则判断出错,否则继续执行。
3、系统试探着把资源分配给进程Pi。
并修改其中的数据Avail、Alloc、Need。
4、系统进行安全性算法的检查。
三、安全性算法其中有两个信号量,Work和Finish。
分别用于表示系统可提供给进程的继续运行所需的各类资源的数目,含m个int型的元素。
而Finish用于标识系统是否有足够的资源分配给进程,使之运行完成,默认为1(不能),从而只有在finish都为0时才能表示安全算法成功。
民大-银行家算法-操作系统实验报告
银行家算法实验报告一、实验题目为了了解系统的资源分配情况,假定系统的任何一种资源在任一种资源在任意时刻只能被一个进程使用。
任何进程已经占用的资源只能由进程自己释放,而不能任由其他进程抢占。
当进程申请的资源不能满足时,必须等待。
因此,只要资源分配算法能保证进程的资源请求,且不出现循环等待,则系统不会出现死锁。
而银行家算法是避免死锁的一种重要方法。
通过编写一个模拟动态资源分配的银行家算法程序,进一步深入理解死锁、产生死锁的必要条件、安全状态等重要概念,并掌握避免死锁的具体实施方法二、实验要求要求编写系统进行资源调度的程序,模拟进程的资源分配算法,了解死锁的产生和避免的办法。
一个是随机动态地进行资源分配的模拟程序,即只要系统当前剩余资源满足进程的当前要求,就立即将资源分配给进程,以观察死锁产生情况;一个是采用银行家算法,有效地避免死锁的产生。
要求用银行家算法和随机算法实现资源分配。
1.设计3-4个并发进程,共享系统的10个同类不可抢占的资源。
各进程动态进行资源的申请和释放。
2.用银行家算法和随机算法分别设计一个资源分配程序,运行这两个程序,观察系统运行情况,并对系统运行的每一步情况进行显示。
二、总的设计思想及语言环境、工具等1.算法设计思路银行家算法又称“资源分配拒绝”法,其基本思想是,系统中的所有进程放入进程集合,在安全状态下系统受到进程的请求后试探性的把资源分配给他,现在系统将剩下的资源和进程集合中其他进程还需要的资源数做比较,找出剩余资源能满足最大需求量的进程,从而保证进程运行完成后还回全部资源。
这时系统将该进程从进程集合中将其清除。
此时系统中的资源就更多了。
反复执行上面的步骤,最后检查进程的集合为空时就表明本次申请可行,系统处于安全状态,可以实施本次分配,否则,只要进程集合非空,系统便处于不安全状态,本次不能分配给他,请进程等待。
2.语言环境、工具计算机基本配置要求:操作系统:WIN 98/2000/XP/2003 等Windows平台内存:256MB及以上主存64KB(Memory)(以KB为单位分配)开发语言:Visual C++ 6.0四、数据结构与模块说明(功能与框图)五、源程序(指导老师验收通过)#include<string.h>#include<iostream.h>#define FALSE 0#define TRUE 1#define W 10 //最大进程数W=10#define R 20 //最大资源总数R=20int M ;int N ;int ALL_RESOURCE[W];int AVAILABLE[R]; //可利用资源向量int MAX[W][R]; //最大需求矩阵int ALLOCATION[W][R]; //分配矩阵int NEED[W][R]; //需求矩阵int Request[R]; //进程请求向量void inputdata(); //数据输入void showdata(); //数据显示void changdata(int k);//进程请求资源数据改变void restoredata(int k); //数据恢复int chksec(int s); //系统安全性的检测int chkmax(int s); //检测最大需求void bank(); //检测分配的资源是否合理void main(){ int i,j;inputdata();for(i=0;i<M;i++){ j=chksec(i);if (j==0) break;}if (i>=M)cout<<"错误提示:经安全性检查发现,系统的初始状态不安全\n"<<endl;else{ cout<<"提示:经安全性检查发现,系统的初始状态安全!"<<endl;bank();}}void inputdata(){ int i=0,j=0,p;cout<<"请输入总进程数:"<<endl;do{cin>>M;if (M>W) cout<<endl<<"总进程数超过了程序允许的最大进程数,请重新输入:"<<endl;}while (M>W);cout<<endl;cout<<"请输入资源的种类数:"<<endl;do {cin>>N;if (N>R)cout<<endl<<"资源的种类数超过了程序允许的最大资源种类数,请重新输入:"<<endl; }while (N>R);cout<<endl;cout<<"请依次输入各类资源的总数量,即设置向量all_resource:"<<endl;for(i=0;i<N;i++) cin>>ALL_RESOURCE[i];cout<<endl;cout<<"请依次输入各进程所需要的最大资源数量,即设置矩阵max:"<<endl;for (i=0;i<M;i++){for (j=0;j<N;j++){do { cin>>MAX[i][j];if (MAX[i][j]>ALL_RESOURCE[j])cout<<endl<<"该最大资源数量超过了声明的该资源总数,请重新输入:"<<endl; }while (MAX[i][j]>ALL_RESOURCE[j]);}}cout<<endl;cout<<"请依次输入各进程已经占据的各类资源数量,即设置矩阵allocation:"<<endl;for (i=0;i<M;i++){for (j=0;j<N;j++){do{ cin>>ALLOCATION[i][j];if (ALLOCATION[i][j]>MAX[i][j])cout<<endl<<"已占有的资源数量超过了声明的最大资源数量,请重新输入:"<<endl;}while (ALLOCATION[i][j]>MAX[i][j]);}}cout<<endl;for (i=0;i<M;i++)for(j=0;j<N;j++)NEED[i][j]=MAX[i][j]-ALLOCATION[i][j];for (j=0;j<N;j++){ p=ALL_RESOURCE[j];for (i=0;i<M;i++){ p=p-ALLOCATION[i][j];AVAILABLE[j]=p;if(AVAILABLE[j]<0)AVAILABLE[j]=0;}}}void showdata(){ int i,j;cout<<"各种资源的总数量,即向量all_resource为:"<<endl;cout<<" ";for (j=0;j<N;j++)cout<<" 资源"<<j<<": "<<ALL_RESOURCE[j];cout<<endl<<endl;cout<<"当前系统中各类资源的可用数量,即向量available为:"<<endl; cout<<" ";for (j=0;j<N;j++)cout<<" 资源"<<j<<": "<<AVAILABLE[j];cout<<endl<<endl;cout<<"各进程还需要的资源数量,即矩阵need为:"<<endl<<endl;for (i=0;i<M;i++){ cout<<"进程P"<<i<<": ";for (j=0;j<N;j++)cout<<NEED[i][j]<<" ";cout<<endl;}cout<<endl;cout<<"各进程已经得到的资源量,即矩阵allocation为: "<<endl<<endl;for (i=0;i<M;i++){ cout<<"进程P"<<i<<": ";for (j=0;j<N;j++)cout<<ALLOCATION[i][j]<<" ";cout<<endl;} cout<<endl;}void changdata(int k){ int j;for (j=0;j<N;j++){AVAILABLE[j]=AVAILABLE[j]-Request[j];ALLOCATION[k][j]=ALLOCATION[k][j]+Request[j];NEED[k][j]=NEED[k][j]-Request[j];}}void restoredata(int k){int j;for (j=0;j<N;j++){ AVAILABLE[j]=AVAILABLE[j]+Request[j];ALLOCATION[k][j]=ALLOCATION[k][j]-Request[j];NEED[k][j]=NEED[k][j]+Request[j];}}int chksec(int s){int WORK,FINISH[W];int i,j,k=0;for(i=0;i<M;i++)FINISH[i]=FALSE;for(j=0;j<N;j++){ WORK=AVAILABLE[j];i=s;do{ if(FINISH[i]==FALSE&&NEED[i][j]<=WORK){WORK=WORK+ALLOCATION[i][j];FINISH[i]=TRUE;i=0;}else{ i++;}}while(i<M);for(i=0;i<M;i++)if(FINISH[i]==FALSE){ return 1;}} return 0;}int chkmax(int s){ int j,flag=0;for(j=0;j<N;j++){if (MAX[s][j]==ALLOCATION[s][j]){ flag=1;AVAILABLE[j]=AVAILABLE[j]+MAX[s][j];MAX[s][j]=0;}} return flag;}c{int i=0,j=0;char flag='Y';while(flag=='Y'||flag=='y'){i=-1;while(i<0||i>=M){ cout<<"请输入需申请资源的进程号(从P0到P"<<M-1<<",否则重新输入!):"; cout<<"p";cin>>i;if(i<0||i>=M)cout<<"输入的进程号不存在,重新输入!"<<endl;}cout<<"请输入进程P"<<i<<"申请的资源数:"<<endl;for (j=0;j<N;j++){ cout<<" 资源"<<j<<": ";cin>>Request[j];if(Request[j]>NEED[i][j]){ cout<<"进程P"<<i<<"申请的资源数大于进程P"<<i<<"还需要"<<j<<"类资源的资源量!";cout<<"申请不合理,出错!请重新选择!"<<endl<<endl;flag='N';break;}else{ if(Request[j]>AVAILABLE[j]){ cout<<"进程P"<<i<<"申请的资源数大于系统可用"<<j<<"类资源的资源量!";cout<<"申请不合理,出错!请重新选择!"<<endl<<endl;flag='N';break;}}}if(flag=='Y'||flag=='y'){ changdata(i);if(chksec(i)){ cout<<endl;cout<<"该分配会导致系统不安全本次资源申请不成功,不予分配"<<endl;cout<<endl;restoredata(i);}else{ cout<<endl;cout<<"经安全性检查,系统安全,本次分配成功,且资源分配状况如下所示:"<<endl;cout<<endl;showdata();if(chkmax(i)){cout<<"在资源分配成功之后,由于该进程所需的某些资源的最大需求量已经满足,"<<endl;cout<<"因此在进程结束后系统将回收这些资源!"<<endl;cout<<"在资源收回之后,各进程的资源需求和分配情况如下所示:"<<endl;showdata();}}}cout<<endl;cout<<" 是否继续银行家算法演示,按'Y'或'y'键继续,按'N'或'n'键退出演示: ";cin>>flag; }}六、运行结果分析1.输入进程数、资源种类数、各类资源总数量、各进程所需要的最大资源数量、各进程所已经占据的各类资源数量2.经安全性检验,系统状态安全,进程P0申请资源3.经安全性检验,系统状态安全,进程P0获得所申请资源4.进程P3申请资源5.经安全性检验,系统状态安全,进程P3获得所申请资源6.进程P1申请资源7.经安全性检验,系统状态安全,进程P1获得所申请资源8.进程P2申请资源9.经安全性检验,系统状态安全,进程P2获得所申请资源5.进程P1申请资源6.经安全性检验,系统状态安全,进程P1获得所申请资源七、总结这次实验中我们可以把操作系统看作是银行家,操作系统管理的资源相当于银行家管理的资金,进程向操作系统请求分配资源相当于用户向银行家贷款。
银行家算法实验报告
银行家算法分析、设计与实现一、设计理论描述本设计的目的是通过编写和调试一个系统动态分配资源的简单模拟程序,观察死锁产生的条件,并采用适当的算法,有效地防止和避免死锁地发生。
要求如下:(1)模拟一个银行家算法;(2)初始化时让系统拥有一定的资源;(3)用键盘输入的方式申请资源;(4)如果预分配后,系统处于安全状态,则修改系统的资源分配情况;(5)如果预分配后,系统处于不安全状态,则提示不能满足请求,设计的主要内容是模拟实现动态资源分配。
同时编写和调试一个系统动态资源的简单模拟程序,观察死锁产生的条件,并使用适当的算法,有效的防止和避免死锁的发生。
银行家算法.顾名思义是来源于银行的借贷业务,一定数量的本金要应多个客户的借贷周转,为了防止银行加资金无法周转而倒闭,对每一笔贷款,必须考察其是否能限期归还。
在操作系统中研究资源分配策略时也有类似问题,系统中有限的资源要供多个进程使用,必须保证得到的资源的进程能在有限的时间内归还资源,以供其他进程使用资源。
如果资源分配不得到就会发生进程循环等待资源,则进程都无法继续执行下去的死锁现象。
把一个进程需要和已占有资源的情况记录在进程控制中,假定进程控制块PCB其中“状态”有就绪态、等待态和完成态。
当进程在处于等待态时,表示系统不能满足该进程当前的资源申请。
“资源需求总量”表示进程在整个执行过程中总共要申请的资源量。
显然,,每个进程的资源需求总量不能超过系统拥有的资源总数, 银行算法进行资源分配可以避免死锁.二、算法描述及数据结构模型1.银行家算法:设进程i提出请求Request[n],则银行家算法按如下规则进行判断。
(1)如果Request[n]>Need[i,n],则报错返回。
(2)如果Request[n]>Available,则进程i进入等待资源状态,返回。
(3)假设进程i的申请已获批准,于是修改系统状态:Available=Available-RequestAllocation=Allocation+RequestNeed=Need-Request(4)系统执行安全性检查,如安全,则分配成立;否则试探险性分配作废,系统恢复原状,进程等待。
银行家算法实验报告
计算机操作系统实验报告一、实验名称:银行家算法二、实验目的:银行家算法是避免死锁的一种重要方法,通过编写一个简单的银行家算法程序,加深了解有关资源申请、避免死锁等概念,并体会和了解死锁和避免死锁的具体实施方法。
三、问题分析与设计:1、算法思路:先对用户提出的请求进行合法性检查,即检查请求是否大于需要的,是否大于可利用的。
若请求合法,则进行预分配,对分配后的状态调用安全性算法进行检查。
若安全,则分配;若不安全,则拒绝申请,恢复到原来的状态,拒绝申请。
2、银行家算法步骤:(1)如果Requesti<or =Need,则转向步骤(2);否则,认为出错,因为它所需要的资源数已超过它所宣布的最大值。
(2)如果Request<or=Available,则转向步骤(3);否则,表示系统中尚无足够的资源,进程必须等待。
(3)系统试探把要求的资源分配给进程Pi,并修改下面数据结构中的数值:Available=Available-Request[i];Allocation=Allocation+Request;Need=Need-Request;(4)系统执行安全性算法,检查此次资源分配后,系统是否处于安全状态。
3、安全性算法步骤:(1)设置两个向量①工作向量Work。
它表示系统可提供进程继续运行所需要的各类资源数目,执行安全算法开始时,Work=Allocation;②布尔向量Finish。
它表示系统是否有足够的资源分配给进程,使之运行完成,开始时先做Finish[i]=false,当有足够资源分配给进程时,令Finish[i]=true。
(2)从进程集合中找到一个能满足下述条件的进程:①Finish[i]=false②Need<or=Work如找到,执行步骤(3);否则,执行步骤(4)。
(3)当进程P获得资源后,可顺利执行,直至完成,并释放出分配给它的资源,故应执行:Work=Work+Allocation;Finish[i]=true;转向步骤(2)。
银行家算法实验报告
银行家算法实验报告实验目的:了解和掌握银行家算法,进一步熟悉进程和如何避免死锁。
实验内容:1、主要程序结构(a)resource allocation algorithm如果要求的资源量+占有的资源总的资源需求量可以carry out allocation(b) test for safety algorithm注:《--- 》中的内容为未具体写明但说明其功能的程序段bool safe(struct state new ){bool possible = true,found=false;process rest[n];//正在执行的进程号int p=n;// 正在执行的进程数量int currentavail[m];//可用资源的一个副本《---为rest和currentavail赋值---》while(possible==true&&p>0){int g=0;《---寻找可以执行完成的进程---》if(found==true){int c=0;《---假设可以执行完的进程以完成,及currentavail[*]=currentavail[*]+new.alloc[g][*];---》rest[g] = -1;--p;found =false;}else{possible=false;}}return possible;}2、实验步骤1)设计结构体#ifndef STATE_H_#define m 3#define n 5struct state{int resource[m];int available[m];int claim[n][m];int alloc[n][m];} ;#define STATE_H_#endif /* STATE_H_ */2)设计实现程序的结构的具体程序Safe算法的具体代码bool safe(struct state new ){bool possible = true,found=false;process rest[n]; //正在执行的进程号int f=0,p=n;// 正在执行的进程数量do{rest[f]=f;++f;}while(f<n);int currentavail[m]; //可用资源的一个副本int i=0;do{currentavail[i]=new.available[i];++i;}while(i<m);while(possible==true&&p>0){int g=0;/*------------------寻找可以执行完成的进程------------------------------------------*/ while(g<n){int h = 0;/*while(h<m){if((new.claim[g][h]-new.alloc[g][h])<=currentavail[h]&&rest[g]!=(-1)){if(h==m-1){found=true;}}++h;}if(found==true)break;++g;}/*-------------------------------------------------------------------------------------*/ if(found==true){int c=0;while(c<m){currentavail[c]=currentavail[c]+new.alloc[g][c];c++;}rest[g] = -1;--p;found =false;}else{possible=false;}}return possible;}实验代码:/*============================================================================ Name : pre.cAuthor :Version :Copyright : Your copyright noticeDescription : Hello World in C, Ansi-style============================================================================ */#include <stdio.h>#include <stdlib.h>#include"state.h"#define bool int#define process int#define false 0#define true 1int main(void) {bool alloc(int,int[],struct state );struct state sta1={{10,5,7},{3,3,2},{{7,5,3},{3,2,2},{9,0,2},{2,2,2},{4,3,3}},{{0,1,0},{2,0,0},{3,0,2},{2,1,1},{0,0,2}}};int request[m];int k=0;while(k>=0){puts("输入要改变资源的进程号");scanf("%d",&k);puts("输入要改变的资源");int i =0;while(i<m){scanf("%d",&request[i]);i++;}if(alloc(k,request,sta1)==true){i=0;puts("输出个进程占用的资源");while(i<n){int j=0;printf("%d ",i);while(j<m){if(i==k){sta1.alloc[k][j]=request[j]+sta1.alloc[k][j];sta1.available[j]=sta1.available[j]-request[j];}printf("%d ",sta1.alloc[i][j]);j++;}printf("\n");++i;}}puts("银行家算法");}return 0;}bool alloc(int l,int request[m],struct state nest){bool safe(struct state news);bool t = false;int i=0;while(i<m){if(nest.alloc[l][i]+request[i]>nest.claim[l][i]){puts("!!resource request error!!");return false;}else if(request[i]>nest.available[i]){puts("suspend process");return false;}else{if(i==m-1){int f=0;while(f<m){nest.alloc[l][f]=nest.alloc[l][f]+request[f];nest.available[f]=nest.available[f]-request[f];f++;}if(safe(nest)==true){t=true;}else{puts(" no safe suspend process");t=false;}}}i++;}return t;}bool safe(struct state new ){bool possible = true,found=false;process rest[n];int f=0,p=n;do{rest[f]=f;++f;}while(f<n);int currentavail[m];int i=0;do{currentavail[i]=new.available[i];++i;}while(i<m);while(possible==true&&p>0){int g=0;while(g<n){int h = 0;while(h<m&&(new.claim[g][h]-new.alloc[g][h])<=currentavail[h]&&rest[g]!=(-1)){if(h==m-1){found=true;}++h;}if(found==true)break;++g;}if(found==true){int c=0;while(c<m){currentavail[c]=currentavail[c]+new.alloc[g][c];c++;}rest[g] = -1;--p;found =false;}else{possible=false;}}return possible;}。
银行家算法实验报告绪论
一、实验背景在计算机系统中,资源分配和死锁问题是操作系统领域的重要研究课题。
在多进程环境下,进程之间会共享系统资源,如CPU、内存、磁盘等。
然而,当多个进程同时申请资源时,可能会出现死锁现象,导致系统瘫痪。
为了避免死锁,研究者提出了多种资源分配算法,其中最具代表性的就是银行家算法。
银行家算法最初由Edsger Dijkstra于1965年提出,旨在解决银行在贷款业务中可能出现的死锁问题。
该算法通过模拟银行家在贷款业务中的决策过程,对资源分配进行动态规划,以确保系统处于安全状态,从而避免死锁的发生。
二、实验目的本次实验旨在通过实现银行家算法,加深对资源分配、死锁和安全性概念的理解,并掌握以下内容:1. 了解资源分配的基本原理和死锁的概念。
2. 掌握银行家算法的原理和实现方法。
3. 能够运用银行家算法对系统资源进行动态分配,并确保系统处于安全状态。
4. 分析实验结果,验证银行家算法的有效性。
三、实验原理1. 资源分配资源分配是指操作系统将资源分配给进程的过程。
在多进程环境下,资源分配策略需要考虑以下因素:(1)资源的类型和数量。
(2)进程对资源的最大需求。
(3)进程当前已分配的资源。
(4)系统可利用的资源。
2. 死锁死锁是指多个进程在执行过程中,因争夺资源而相互等待,导致系统无法继续执行的现象。
产生死锁的必要条件包括:(1)互斥条件:资源不能被多个进程同时占用。
(2)请求和保持条件:进程在等待资源时,仍保持已占有的资源。
(3)不剥夺条件:进程不能被强制剥夺已占有的资源。
(4)循环等待条件:存在一个进程序列,其中每个进程都在等待前一个进程所持有的资源。
3. 安全状态安全状态是指系统可以按照某种顺序为每个进程分配资源,使得所有进程都可以顺利完成的状态。
判断系统是否处于安全状态的方法如下:(1)计算每个进程的最大需求。
(2)计算系统可利用的资源。
(3)从最大需求中减去已分配的资源,得到剩余需求。
(4)判断剩余需求是否小于等于系统可利用的资源。
银行家算法实验报告
银行家算法实验报告引言:在计算机科学领域,由于资源的有限性,进程资源分配问题一直备受关注。
而银行家算法被广泛应用于操作系统中,用于确保资源的安全分配。
本文旨在介绍银行家算法的原理和应用,并通过实验报告来验证该算法的有效性和可行性。
1. 银行家算法简介银行家算法是由美国学者Dijkstra提出的一种资源分配和避免死锁的算法。
其基本思想是通过银行家的原则来避免系统陷入死锁状态,保证资源分配的安全性和可行性。
银行家算法适用于具有多个进程和多个资源的并发系统中。
2. 银行家算法原理银行家算法基于两个重要的概念:安全性和可分配性。
安全性表示在系统当前状态下,是否存在一种资源分配序列可以使系统避免死锁状态。
可分配性表示系统是否能够满足进程对资源的请求。
银行家算法的实现需要以下几个关键步骤:(1) 初始化:对每个进程设置最大需求量、已分配资源量和需求资源量。
(2) 效验:判断系统当前状态下资源是否满足所有进程的需求,即判断系统是否处于安全状态。
(3) 分配:若系统处于安全状态,则根据某种资源分配策略,为进程分配资源。
(4) 请求:进程请求资源。
(5) 回收:进程释放资源。
3. 银行家算法的实验验证为了验证银行家算法的有效性和可行性,我们设置了一个简单的实验环境,模拟一个有限的资源系统,包含3个进程和3种不同类型的资源。
实验过程如下:(1) 初始化:对每个进程设置最大需求量、已分配资源量和需求资源量。
设置3个进程的最大需求量分别为{5, 4, 3},已分配资源量分别为{1, 2, 2},需求资源量分别为{3, 2, 0}。
(2) 效验:判断系统当前状态下资源是否满足所有进程的需求。
经过实验验证,我们发现系统当前状态下资源无法满足进程2的资源需求。
为了保证系统的安全性和避免死锁,根据银行家算法原理,我们将不满足资源需求的进程2暂停,并回滚到初始状态。
重新调整资源分配后,系统进入了安全状态。
(3) 分配:为进程1和进程3分配资源。
c语言银行家算法实验报告
c语言银行家算法实验报告C语言银行家算法实验报告引言:计算机科学领域中,操作系统的资源管理是一个十分重要的课题。
在多任务处理系统中,多个进程同时竞争有限的资源,如何合理地分配和调度资源,以保证系统的稳定性和效率,是一个关键问题。
银行家算法(Banker's Algorithm)是一种经典的资源分配算法,它通过分析系统的资源状态和进程的资源需求,来判断是否能够安全地分配资源,从而避免产生死锁。
一、实验目的本次实验旨在通过C语言编程实现银行家算法,加深对资源管理和死锁问题的理解,并通过实际案例验证银行家算法的有效性。
二、实验环境本次实验使用C语言进行编程,并在Linux操作系统下进行测试。
三、实验过程1. 设计数据结构在开始编写代码之前,我们需要先设计适合的数据结构来表示系统资源和进程的状态。
在银行家算法中,我们需要记录系统中的可用资源数量、各个进程的最大需求资源数量、已分配资源数量和需要资源数量等信息。
通过定义合适的数据结构,我们可以方便地进行资源的分配和回收。
2. 实现银行家算法根据银行家算法的原理,我们可以将其分为两个步骤:安全性检查和资源分配。
在安全性检查中,我们需要判断当前系统状态下是否存在安全序列,即是否能够满足所有进程的资源需求,避免死锁的发生。
在资源分配中,我们需要根据当前系统状态和进程的资源需求,动态地分配和回收资源。
3. 编写测试用例为了验证银行家算法的正确性和有效性,我们需要编写一些测试用例。
测试用例应该包括各种不同的进程资源需求和系统资源状态,以覆盖不同情况下的资源分配和回收。
4. 运行测试用例在编写完测试用例后,我们可以运行程序,观察输出结果。
通过比较实际输出与预期结果,我们可以判断银行家算法的正确性和有效性。
四、实验结果与分析通过运行多个测试用例,我们可以得出以下结论:1. 银行家算法能够有效地避免死锁的发生。
在安全性检查过程中,如果存在安全序列,那么系统可以继续分配资源,否则需要阻塞等待。
银行家算法实验报告c语言
银行家算法实验报告c语言银行家算法实验报告引言:计算机科学中的银行家算法是一种资源分配和避免死锁的算法。
它是由艾德加·戴克斯特拉(Edsger Dijkstra)在1965年提出的。
银行家算法通过判断一个系统是否处于安全状态来决定是否分配资源给进程。
本实验旨在使用C语言实现银行家算法,并通过一系列的实例来验证其有效性。
一、实验背景银行家算法是为了解决资源分配中的死锁问题而提出的。
在多进程系统中,每个进程都需要一定数量的资源来完成任务。
然而,如果资源分配不当,可能会导致死锁的发生,即所有进程都陷入无法继续执行的状态。
银行家算法通过合理地分配资源,避免了死锁的发生。
二、实验目的本实验的主要目的是通过C语言实现银行家算法,并通过实例验证其正确性和有效性。
具体而言,我们将模拟一个系统中的多个进程,并为每个进程分配资源。
然后,我们将使用银行家算法来判断系统是否处于安全状态,从而决定是否继续分配资源。
三、实验过程1. 创建进程和资源我们首先创建了5个进程和3种资源。
每个进程需要的资源数量是随机生成的,以模拟真实情况下的资源需求。
2. 分配资源根据银行家算法的原则,我们按照以下步骤来分配资源:- 首先,检查每个进程的资源需求是否小于等于系统当前可用的资源数量。
- 如果满足条件,将资源分配给该进程,并更新系统剩余资源数量。
- 如果不满足条件,暂时不分配资源给该进程,继续检查下一个进程。
3. 判断系统状态在每次资源分配后,我们需要判断系统是否处于安全状态。
为此,我们使用银行家算法的核心原则:只有当系统能够为每个进程提供所需的资源时,系统才是安全的。
我们通过遍历所有进程来检查其资源需求是否小于等于系统剩余资源数量,如果满足条件,说明系统是安全的。
4. 实例验证我们进行了多个实例验证,以确保银行家算法的正确性。
在每个实例中,我们模拟了不同的进程和资源需求,并观察系统的状态。
通过比较实验结果和预期结果,我们验证了银行家算法的有效性。
OS银行家算法实验报告
《操作系统原理》实验报告银行家算法实验专业:计算机科学与技术学号:************姓名:***实验日期:2012-5-9一、实验目的通过实验用编程语言模拟银行家诉法来加强对银行家安全算法的理解和掌握。
二、实验内容熟悉避免死锁发生的方法,死锁与安全序列的关系,编程实现银行家算法,要求输出进程的安全序列。
三、算法中用到的数据结构1.可利用资源向量Available2.最大需求矩阵Max3.分配矩阵Allocation4.需求矩阵Need模拟实现银行家算法以避免死锁的出现.分两部分组成:第一部分:银行家算法(扫描)1.如果Request<=Need,则转向2;否则,出错2.如果Request<=Available,则转向3,否则等待3.系统试探分配请求的资源给进程4.系统执行安全性算法第二部分:安全性算法1.设置两个向量(1).工作向量:Work=Available(表示系统可提供给进程继续运行所需要的各类资源数目)(2).Finish:表示系统是否有足够资源分配给进程(True:有;False:没有).初始化为False2.若Finish[i]=False&&Need<=Work,则执行3;否则执行4(I为资源类别)3.进程P获得第i类资源,则顺利执行直至完成!并释放资源:Work=Work+Allocation;Finish[i]=true;转24. 若所有进程的Finish[i]=true,则表示系统安全;否则,不安全!四、算法流程图五、实现代码#include <stdio.h>#define P_NUM 5#define S_NUM 3int Max[P_NUM][S_NUM],Allocation[P_NUM][S_NUM],Need[P_NUM][S_NUM];int Available[S_NUM],Request[S_NUM];int Work[S_NUM],Finish[P_NUM],CurrentProcessId=-1,Arrange[P_NUM],CurrentId=0; FILE *fpr,*fpw;int times=0;void init(){int i=0,j=0;for(i=0;i<P_NUM;i++){for(j=0;j<S_NUM;j++){scanf("%d",&Max[i][j]);}for(j=0;j<S_NUM;j++){scanf("%d",&Allocation[i][j]);Need[i][j]=Max[i][j]-Allocation[i][j];}Finish[i]=0;}for(j=0;j<S_NUM;j++){scanf("%d",&Available[j]);}}void allocation(){int j=0,reasonable=1;if(CurrentProcessId>-1 && CurrentProcessId<P_NUM){printf("P%d Requests :( ",CurrentProcessId);for(j=0;j<S_NUM;j++){Need[CurrentProcessId][j]=Need[CurrentProcessId][j]-Request[j];Allocation[CurrentProcessId][j]=Allocation[CurrentProcessId][j]+Request[j];Available[j]=Available[j]-Request[j];printf("%d ",Request[j]);if(Need[CurrentProcessId][j]<0 || Available[j]<0)reasonable=0;}printf(")\n");if(reasonable==0){UnAllocation();printf("The Request is not reasonable! The below table is same with the top table! \n");}}}int UnAllocation(){int j=0;if(CurrentProcessId>-1 && CurrentProcessId<P_NUM){for(j=0;j<S_NUM;j++){Need[CurrentProcessId][j]=Need[CurrentProcessId][j]+Request[j];Allocation[CurrentProcessId][j]=Allocation[CurrentProcessId][j]-Request[j];Available[j]=Available[j]+Request[j];}}}void safeCheck(){int j=0,processNo=0,times=0;for(j=0;j<S_NUM;j++){Work[j]=Available[j];}processNo=meetCommand();if(processNo<0){UnAllocation();printf("this state is not safty!\n");}else{printf("Assign source in sequence :");for(j=0;j<P_NUM;j++){printf("→P%d",Arrange[j]);}printf("\n\n\n\n\n");}CurrentProcessId=-1;for(j=0;j<P_NUM;j++){Finish[j]=0;Arrange[j]=0;}}int meetCommand(){int meet=0,finish=1,i=0,j=0,maxUnFinish=0;for(i=0;i<P_NUM;i++){if(Finish[i]==0){finish=0;maxUnFinish=i;}}if(finish==1)return 0;for(i=0;i<P_NUM ;i++){if(Finish[i]==0){meet=0;for(j=0;j<S_NUM;j++){if(Need[i][j]>Work[j])meet=-1;}if(meet==0 ){Finish[i]=1;printCheckInfo(i);for(j=0;j<S_NUM;j++){Work[j]=Work[j]+Allocation[i][j];}Arrange[CurrentId]=i;CurrentId++;meetCommand();}if(i==maxUnFinish && meet==-1)return -1;}}return 0;}void printInfo(){int i=0,j=0;printf("┌───────┬────────┬─────────┬─────────┬────────┐\n");printf("││Max │Allocation │Need │Available │\n");printf("│processID ├────────┼─────────┼─────────┼────────┤\n");printf("││ A B C │ A B C │ A B C │ A B C │\n");printf("├───────┼────────┼─────────┼─────────┼────────┤\n");for(i=0;i<P_NUM;i++){printf("│P%d │",i);for(j=0;j<S_NUM;j++){printf(" %d ",Max[i][j]);}printf("│");for(j=0;j<S_NUM;j++){printf("%d ",Allocation[i][j]);}printf("│");for(j=0;j<S_NUM;j++){printf("%d ",Need[i][j]);}printf(" │");if(i==0){for(j=0;j<S_NUM;j++){printf("%d ",Available[j]);}printf(" │\n");}if(i>0)printf(" │\n");}printf("└───────┴────────┴─────────┴─────────┴────────┘\n");}int printCheckInfo(int i){int j=0,allFinsh=1;if(times==0){printf("┌───────┬────────┬─────────┬─────────┬────────┐\n");printf("││Work │Allocation │Need ││\n");printf("│processID ├────────┼─────────┼─────────┤States │\n");printf("││ A B C │ A B C │ A B C ││\n");printf("├───────┼────────┼─────────┼─────────┼────────┤\n");times++;}printf("│P%d │",i);for(j=0;j<S_NUM;j++){if(Work[j]>9)printf(" %d ",Work[j]);if(Work[j]<10)printf(" %d ",Work[j]);}printf("│");for(j=0;j<S_NUM;j++){printf("%d ",Allocation[i][j]);}printf("│");for(j=0;j<S_NUM;j++){printf("%d ",Need[i][j]);}printf(" │");for(j=0;j<P_NUM;j++){printf("%d ",Finish[j]);allFinsh*=Finish[j];}printf(" │\n");if(allFinsh==0)printf("├───────┼────────┼─────────┼─────────┼────────┤\n");if(allFinsh> 0)printf("└───────┴────────┴─────────┴─────────┴────────┘\n");}main(){int j=0;char comeOn;fpr = fopen("banker.txt","r");fpw = fopen("outcoming.txt","w");printf("程序运行结果如下:\n");init();printInfo();allocation();safeCheck();scanf("\n%c",&comeOn);while(comeOn=='y'|| comeOn=='Y'){printInfo();scanf("%d",&CurrentProcessId);for(j=0;j<S_NUM;j++){scanf("%d",&Request[j]);}allocation();times=0;CurrentId=0;safeCheck();scanf("\n%c",&comeOn);}}六、总结通过了这次实验更透彻的理解了银行家算法如何来避免思索的产生,以及对银行家算法的具体实现步骤更加清晰的理解。
银行家算法实验报告
实验二银行家算法一、实验内容简要描述1.实验目标:加深了解有关资源申请、避免死锁等概念,并体会和了解死锁和避免死锁的具体实施方法。
要求编写和调试一个系统动态分配资源的简单模拟程序,观察死锁产生的条件,并采用银行家算法,有效的防止和避免死锁的发生。
2.实验要求:银行家算法是避免死锁的一种重要方法,本实验要求用高级语言编写和调试一个简单的银行家算法程序。
用银行家算法实现资源分配。
设计五个进程{p0,p1,p2,p3,p4}共享三类资源{A,B,C}的系统,例如,{A,B,C}的资源数量分别为10,5,7。
进程可动态地申请资源和释放资源,系统按进程的申请动态地分配资源,要求程序具有显示和打印各进程的某一个时刻的资源分配表和安全序列;显示和打印各进程依次要求申请的资源号以及为某进程分配资源后的有关资源数据。
二、报告主要内容1.设计思路A、设计进程对各在资源最大申请表示及初值确定。
B、设定系统提供资源初始状态。
C、设定每次某个进程对各类资源的申请表示。
D、编制程序,依据银行家算法,决定其申请是否得到满足。
2.主要数据结构假设有M个进程N类资源,则有如下数据结构:MAX[M*N] M个进程对N类资源的最大需求量AVAILABLE[N] 系统可用资源数ALLOCATION[M*N] M个进程已经得到N类资源的资源量NEED[M*N] M个进程还需要N类资源的资源量3. 主要代码#include <iostream.h>#include "stdio.h"//#include "windows.h"const unsigned short c = 3;//资源类数const unsigned short t = 5;//进程数void Print(); //用于打印输出表格的函数void Input();//用于输入的函数void tryfenpei(int i);//试分配函数void refenpei(int i);//恢复数据函数void checksafe(int s);//安全检测函数//定义初始化数组int Available[c],Max[t][c],Allocation[t][c],Need[t][c],Request[c];int in;//用户选择的进程号/*----------------------------------------------------------------*/int main(int argc, char *argv[]){int i;char ch='Y';cout<<"初始化数据"<<endl;Input();//输入相关数据函数Print();//打印输出相关数据表函数cout<<"初始化完成!..."<<endl<<endl<<endl;do{if(ch=='Y'||ch=='y'){cout<<"欢迎进入实验!请稍后..."<<endl;// Sleep(1000);cout<<"已顺利进入实验..."<<endl;cout<<"请输入发起请求的进程号(0-4):";while(cin>>in){if(!(0<=in&&in<=4)){cout<<"不存在该进程,请重新输入"<<endl;}else break;};cout<<"您输入的是"<<"p["<<in<<"]"<<" 进程"<<endl;cout<<"该进程需求量为:";for(i=0;i<c;i++)cout<<Need[in][i]<<" ";cout<<endl;cout<<"请输入请求资源的数目:";//输入格式为X for(i=0;i<c;i++){while(cin>>Request[i]){if(Request[i]<0) cout<<"错误!输入的数字无效."<<endl;elseif(Request[i]>Need[in][i]) cout<<"错误!超出进程需求量"<<endl<<endl;if(Request[i]>Available[i]) cout<<"错误!系统还没有足够的可用资源量满足进程需要"<<endl<<endl;else break;}}cout<<"输入成功,您输入的是:"<<Request[0]<<" "<<Request[1]<<" "<<Request[2];cout<<endl;cout<<"开始执行银行家算法,下面进行试分配..."<<endl;tryfenpei(in);//分配函数//Sleep(1000);cout<<"试分配完成!"<<endl;cout<<"进入安全性检测..."<<endl;//Sleep(1000);checksafe(in);//安全性检测函数cout<<"需要继续实验吗?(y-继续n终止)";}elseif(ch=='N'||ch=='n'){cout<<"感谢您的使用,祝您愉快!"<<endl<<"正在退出..."<<endl;break;}elsecout<<"输入无效!请重新输入."<<endl;}while(cin>>ch);return 0;}/*---------------------main函数结束----------------------------------*//*-------------------------输出函数----------------------------------*/void Print(){int i,j;cout<<" 进程个数:"<<t<<" 资源个数:"<<c<<endl;cout<<"正在更新数据..."<<endl;//Sleep(1500);cout<<"|-----|----------|------------|----------|-----------|"<<endl;cout<<"|----|最大需求矩阵|已分配矩阵-|-需求矩阵-可用资源向量|"<<endl;cout<<"|\ 资源| Max | Allocation | Need | Available |"<<endl;cout<<"| \ | A B C | A B C | A B C | A B C |"<<endl;cout<<"|进程\ | | | | |"<<endl; cout<<"|-----|----------|------------|----------|-----------|"<<endl;for(i=0;i<5;i++){cout<<"| p"<<i<<" | ";for(j=0;j<3;j++){cout<<Max[i][j]<<" ";}cout<<"|";for(j=0;j<3;j++){cout<<" "<<Allocation[i][j];}cout<<" |";for(j=0;j<3;j++){cout<<" "<<Need[i][j];}cout<<" |";if(i==0){for(j=0;j<3;j++){cout<<" "<<Available[j];}cout<<" |";}if(i>0){cout<<" |";}cout<<endl;}cout<<"|-----|----------|------------|----------|-----------|"<<endl;}/*-------------------------输出函数结束--------------------------------*//*--------------------------输入函数----------------------------------*/void Input(){for(int j=0;j<c;j++){cout<<"请输入Available["<<j<<"]:";while(cin>>Available[j]){if(Available[j]<0)cout<<"输入数字无效,请重新输入"<<endl;else break;};}for(int k=1;k<4;k++)//其他三个属性和一次打印输出表{for(int l=0;l<t;l++)//五个进程循环输入{for(int m=0;m<c;m++)//三个类资源ABC循环输入{if(k==1&&m<t){cout<<"请输入Max["<<l<<"]["<<m<<"]:";while(cin>>Max[l][m]){if(Max[l][m]<0)cout<<"输入数字无效,请重新输入"<<endl;else break;};}if(k==2&&m<t){cout<<"请输入Allocation["<<l<<"]["<<m<<"]:";while(cin>>Allocation[l][m])if(Allocation[l][m]<0)cout<<"输入数字无效,请重新输入"<<endl;else break;//cout<<"Allocation["<<l<<"]["<<m<<"]="<<Allocation[l][m]<<endl;}if(k==3&&m<t)Need[l][m]=Max[l][m]-Allocation[l][m];}}}}//*-------------------------输入函数结束----------------------------------*//*-------------------------试分配函数----------------------------------*/void tryfenpei(int i){for(int f=0;f<c;f++){Available[f] = Available[f] - Request[f];Allocation[i][f] = Allocation[i][f] + Request[f];Need[i][f] = Need[i][f]-Request[f];}}/*-------------------------试分配函数结束----------------------------------*//*-------------------------恢复数据函数----------------------------------*/void refenpei(int i){for(int f=0;f<c;f++){Available[f] = Available[f] + Request[f];Allocation[i][f] = Allocation[i][f] - Request[f];Need[i][f] = Need[i][f]+Request[f];//cout<<Available[f]<<" "<<Allocation[i][f]<<" "<<Need[i][f]<<endl;}}/*-------------------------恢复数据函数结束----------------------------------*//*-------------------------安全检测函数----------------------------------*/void checksafe(int s){int Work,flag,temp[t],i,j,l=0,k=0;bool Finish[t];for(i=0;i<t;i++)Finish[i]=false;for(j=0;j<3;j++){Work=Available[j];//cout<<"Work="<<Work<<endl;for(i=0;i<t;i++){if(Finish[i]==true) l++;//用l是否达到5来判断这条进程A类资源或者B类资源是否通过安全检测,C类资源没有经过这里}if(l==5)//一共有三类资源A B C,一条进程下面的安全性检测只检测了A类。
实验报告_银行家算法
1. 题目分析1.1 设计目的●理解死锁产生的原因和必要条件●了解避免死锁的几种基本方法●掌握银行家算法及安全性算法1.2 设计内容设计内容包括银行家算法和安全性算法,以及用VC界面实现输出1.3 相关知识概述银行家算法是一种最有代表性的避免死锁的算法。
要解释银行家算法,必须先解释操作系统安全状态和不安全状态。
安全状态:如果存在一个由系统中所有进程构成的安全序列P1,…,Pn,则系统处于安全状态。
安全状态一定是没有死锁发生。
不安全状态:不存在一个安全序列。
不安全状态一定导致死锁。
安全序列:一个进程序列{P1,…,Pn}是安全的,如果对于每一个进程Pi(1≤i≤n),它以后尚需要的资源量不超过系统当前剩余资源量与所有进程Pj (j < i )当前占有资源量之和。
2. 概要设计2.1主要数据结构描述static int MAX[5][3]; //最大需求矩阵static int AVAILABLE[3]; //可利用资源矩阵static int ALLOCATION[5][3]; //分配矩阵static int NEED[5][3]; //需求矩阵因为数组成员MAX,AVAILABLE, ALLOCATION, NEED的值每次调用一次银行家算法,如果分配成功,都会改变,所以将他们设定为静态成员变量。
int Request[3]; //请求向量int Work[3]; //工作向量bool FINISH[5];//标记系统是否有足够的资源分配给进程2.2 流程图(1)银行家算法流程图单击“执行银行家算法”按钮时会调用OnButton1()函数,相当于银行家算法注:只要不按“退出”按钮退出程序,数组MAX,A V AILABLE, ALLOCATION, NEED中会保留上一次执行完后变化的值,不停的单击“进行银行家算法”按钮,程序会在上一次执行完后的基础上反复的执行银行家算法。
(2)安全性算法流程图3. 详细设计3.1 主要算法描述当进程pi提出资源申请时,系统执行下列步骤:(1)若Request≤Need,转(2);否则错误返回(2)若Request≤Available,转(3);否则进程等待(3)假设系统分配了资源,则有:Available:=Available-Request;Allocation:=Allocation+Request;Need:=Need-Request若系统新状态是安全的,则分配完成若系统新状态是不安全的,则恢复原状态,进程等待安全性检查的步骤:(1) Work:=Available;Finish:=false;(2) 寻找满足条件的i:Finish=false;Need≤Work;如果不存在,则转(4)(3) Work:=Work+Allocation;Finish:=true;转(2)(4) 若对所有i,Finish=true,则系统处于安全状态,否则处于不安全状态3.2 程序界面设计4. 编码实现4.1 开发工具简介Visual C++集成开发环境下下实现的4.2 部分程序源码int CSisuoDlg::MAX[5][3]={{7,5,3},{3,2,2},{9,0,2},{2,2,2},{4,3,3}};int CSisuoDlg::AVAILABLE[3]={3,3,2};int CSisuoDlg::ALLOCATION[5][3]={{0,1,0},{2,0,0},{3,0,2},{2,1,1},{0,0,2}}; int CSisuoDlg::NEED[5][3]={{7,4,3},{1,2,2},{6,0,0},{0,1,1},{4,3,1}};int CSisuoDlg::safe(){int i,j,k,l=0;int Work[3];bool FINISH[5];int p[5];for(i=0;i<3;i++)Work[i]=AVAILABLE[i];for(i=0;i<5;i++){ FINISH[i]=false;}for(i=0;i<5;i++){if(FINISH[i]==true){ continue;}else{for(j=0;j<3;j++){if(NEED[i][j]>Work[j]){break;}}if(j==3)//找到满足要求的进程{FINISH[i]=true;for(k=0;k<3;k++){Work[k]+=ALLOCATION[i][k];}p[l++]=i;//记录安全序列i=-1;//每次都是从头开始找}else{continue;}}if(l==5){show+="经安全性检查,系统安全,本次分配成功。
银行家算法全报告
} }
if(count==5) printf("\n 各进程顺利执行!\n"); else printf("\n 资源分配足,产生死锁!\n");
五、实验过程原始记录(数据、图表、计算等) #include<stdio.h> int main(int argc, char *argv[]) {
int claim[5][3] = {{7,5,3},{3,2,2},{9,0,2},{2,2,2},{4,3,3}}; //进程 运行申请的总资源
int allocation[5][3] = {{0,1,0},{2,0,0},{3,0,2},{2,1,1},{0,0,2}}; int p,s = 0; //p 代表进程 s 代表资源的种类 int count=0; //每个进程成功分配自动加 1 int need[5][3] = {{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0}}; //进程 还需要的每种资源数 int result[5] = {-1,-1,-1,-1,-1}; //进程是否得到了满足 int work[3] = {3,3,2}; printf("总资源:\n\tA\tB\tC\n\t10\t5\t7\n");
七、实验心得 银行家算法是为了使系统保持安全状态。把操作系统看作是银行家,操作系
银行家算法实习报告
青岛农业大学学生实习报告实习名称:软件系统课程设计实习时间: -- 年第 2学期专业班级:姓名(学号):同组成员:***师:***年 3 月 22 日(一)编译原理部分一、实习题目将词法分析器设计成单独旳程序或供语法分析器调用旳子程序,功能涉及:规定可以辨认数字、标记符、核心字、运算符等。
二、设计思路及算法描述词法分析程序旳功能:输入源程序,输出单词符号,如图所示:源程序单词符号解决过程:在扫描源程序字符串时,一旦辨认出核心字、分隔符、标记符、无符号常数中之一,即以单词形式(各类单词均采用相似旳构造,即二元式编码形式)输出。
每次调用词法分析程序,它均能自动继续扫描下去,形成下一种单词,直至整个源程序所有扫描完毕,并形成相应旳单词串形式旳源程序。
本程序规定:(1)核心字"begin","end","if","then","else","while","write","read","do", "call","const","char","until","procedure","repeat"(2)运算符:"+","-","*","/","="(3)界符:"{","}","[","]",";",",",".","(",")",":"(4)其他标记如字符串,表达以字母开头旳标记符。
银行家算法实验报告
银行家算法一、课题内容和要求银行家算法是一种最有代表性的避免死锁的算法。
在避免死锁方法中允许进程动态地申请资源,但系统在进行资源分配之前,应先计算此次分配资源的安全性,若分配不会导致系统进入不安全状态,则分配,否则等待。
通过编写一个简单的银行家算法程序,加深了解有关资源申请、避免死锁等概念,并体会和了解死锁和避免死锁的具体实施方法。
二、需求分析本设计的目的是通过编写和调试一个系统动态分配资源的简单模拟程序,观察死锁产生的条件,并采用适当的算法,有效地防止和避免死锁地发生。
总体要求如下:(1)模拟一个银行家算法;(2)了解算法中用的各种数据结构;(3)系统的初始状态信息从文本文件读取;(4)判断是否存在安全序列,输出任意一个安全序列即可;(5)判断系统是否可以满足进程的请求。
此次课程设计的主要内容时模拟实现动态资源分配。
同时要求编写和调试一个系统动态资源的简单模拟程序,观察死锁产生的条件,并使用适当的算法,有效的防止和避免死锁的发生。
银行家算法是避免死锁的一种重要方法,通过编写一个简单的银行家算法程序,加深了解有关资源申请、避免死锁等概念,并体会和了解死锁和避免死锁的具体实施方法。
三、概要设计1.银行家算法的设计思路先对用户提出的请求进行合法性检查,即检查请求的是不大于需要的,是否不大于可利用的。
若请求合法,则进行试分配。
最后对试分配后的状态调用安全性检查算法进行安全性检查。
若安全,则分配,否则,不分配,恢复原来状态,拒绝申请。
2.银行家算法中用到的主要数据结构可利用资源向量 int Available[j] j为资源的种类。
最大需求矩阵 int Max[i][j] i为进程的数量。
分配矩阵 int Allocation[i][j]需求矩阵 int need[i][j]= Max[i][j]- Allocation[i][j]申请各类资源数量 int Request i[j] i进程申请j资源的数量工作向量 int Work[x] int Finish[y]3.银行家算法bank()进程i发出请求申请k个j资源,Request i[j]=k(1)检查申请量是否不大于需求量:Request i[j]<=need[i,j],若条件不符重新输入,不允许申请大于需求量。
银行家算法实验报告
1 需求分析....................................................................................................................................... 2
1.1 输入的形式和输入值的范围.......................................................................... 2 1.2 输出的形式...................................................................................................... 3 1.3 程序所能达到的功能...................................................................................... 4 1.4 测试数据 ...................................................................................................... 4
7) 该进程所需的各资源数目。输入类型为 int 的数组,形式类似“各资源现 有数目” ,但应该注意,其范围应当不大于剩余资源的数量,即 Request[i]<=Available[i]。
1.2 输出的形式
1) 首先要求用户输入初始化数据,系统将依次输出以下提示: 请输入进程的数目: 请输入资源的种类数目: 请输入每个进程最多所需的各资源数目: 请输入每个进程已分配的各资源数目: 请输入各个资源现有的数目: 当输入第四项“每个进程已分配的各资源数目”时,输入的已分配资源数若 大于每个进程最多所需的各资源数,即 Allocation[i][j]>Max[i][j],系统将提示哪 个进程的第几个资源分配出错,提示如下: 您输入的第 n 个进程所拥有的第 m 个资源数错误! 2) 完成数据初始化后,将列出系统的进程及资源情况,形式如下: 现系统的进程及资源情况如下: Available: 资源 A:a Need: 进程 0:a0 进程 1:a1 „„ Allocation: 进程 0:a0 进程 1:a1 „„ 3) 接着演示进程申请资源,系统将依次输出以下提示: 请输入要申请资源的进程号: 请输入进程所请求的各资源的数目: b0 b1 c0 c1 b0 b1 c0 c1 资源 B:b 资源 C:c „„
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
银行家算法实验报告关键字:银行家算法、安全状态、不安全状态、向量矩阵、进程、死锁、资源、就绪状态、执行状态、阻塞状态;一实验名称进程同步互斥问题二实验目的2.1切实加深对进程死锁的认识;2.2正确理解系统的安全状态与不安全状态;2.3更进一步地理解和掌握银行家算法;三实验要求3.1将本实验分成两个阶段,第一阶段实现系统安全性检测算法;第二阶段实现银行家算法;3.2要求用户能自主地输入不同的向量矩阵;3.3你的程序能正确输出不同的运算结果;3.4你的程序应具备良好的容错能力;3.5力求用户界面的简洁美观;四实验原理4.1 进程及进程死锁;4.1.1 进程:是操作系统中最基本、最重要的概念,但直到目前还没有一个统一的定义,下面通过能反映进程实质的几点描述来认识进程:①进程是程序的一次执行;②进程是可以和别的计算并发执行的计算;③进程是程序在一个数据集合上运行的过程,是系统进行资源分配和调度的一个独立单位;④进程是一个具有一定功能的程序关于某个数据集合的一次运行活动。
进程具有几个基本的特征:动态性、并发性、独立性、异步性;每个进程通常由程序段、数据段和进程控制块三部分组成,其中进程控制块能唯一标识一个进程。
进程执行时间的间断性,决定了进程可能具有多种状态。
事实上,运行中的进程至少具有以下三种基本状态:就绪状态:进程已获得除处理机以外的所有资源,一旦分到了处理机就可以立即执行,这时进程所处的状态为就绪状态;执行状态:又称运行状态。
当一个进程获得必要的资源,并占有处理机,即在处理机上运行,此时进程所处的状态为执行状态;阻塞状态:又称等待状态,正在执行的进程,由于发生了某事件而暂时无法执行下去(如等待输入/输出完成),此时进程所处的状态称为阻塞状态。
进程并非固定处于某一状态,它随着自身的推进和外界条件的变化而发生变化。
4.1.2 进程死锁进程死锁是因多个进程因竞争资源而造成的一种僵局,若无外力作用,这些进程都无法向前推进。
例如,假设系统中有一台打印机和一台输入设备,进程P1正占用输入设备,同时又提出使用打印机的请求,但此时答应机正被进程P2所占用。
而P2在未释放打印机之前,又提出请求使用正被P1占用的输入设备的请求。
这样,两个进程相互无休止地等待下去,均无法继续执行,此时两个进程陷入死锁状态。
4.2进程死锁产生的原因;进程产生死锁有以下两点:①系统资源不足。
在上面举的例子里,如果输入设备不止被P1占用的一台,那么P2申请输入设备时,就可以得到满足,也就不会让P1、P2陷入死锁;②进程推进顺序不当。
在上面举的例子里,如果P2在P1提出使用输入设备前,已经完成了对输入设备和打印机的使用,并且释放了它们;或者是在进程P2提出使用打印机的请求之前,进程P1已经完成了对输入设备和打印机的使用,并且释放了它们,则均不会发生死锁。
4.3死锁产生的必要条件;死锁产生的必要条件有四条:①互斥条件在某一段时间里,某资源被一个进程所占有,不能为别的进程使用;②不剥夺条件进程所获得的资源在为使用完之前,不能被其他进程强行夺走,即只能由获得该资源的进程自己来释放;③部分分配条件进程每次申请它所需要的一部分资源。
在等待新资源的同时,进程继续占用已分配到的资源;④环路条件存在一种进程资源的循环等待链,链中的每一个进程已获得资源的同时被链中下一个进程所请求。
4.4进程死锁的预防、避免和检测;4.4.1 死锁的预防对资源加以某种限制,以使死锁不会发生。
这种死锁的预防是静态的,基本的方法是相对应上面的产生死锁的四个必要条件,采取破坏的方式,以达到死锁不会产生的目的。
4.4.2 死锁的避免死锁的避免是对进程在申请某类资源时所使用的命令加以检测,通过这种方式来避免死锁的发生,相对于死锁的预防来说,这种方式是动态的。
另外,死锁的预防施加了比较强的限制条件,虽然实现起来比较简单,但是却严重损害了系统性能。
在避免死锁的方法中,所施加的限制条件较弱,有可能获得较好的系统性能。
4.4.3死锁的检测死锁的检测是在死锁发生以后采取的一种方式,能够把死锁检测出来并解除之,它是动态的。
前面两种方式,都是在系统为进程分配资源时施加限制条件或进行检测,若系统为进程分配资源时不采取任何措施,则应该提供检测和解除死锁的手段。
死锁的解除常用两种方法:资源剥夺法:当发现死锁时,从其他进程剥夺足够数量的资源给死锁进程,以解除死锁状态;撤消进程法:此方法是采用强制手段从系统中撤消一个或一部分死锁进程,并剥夺这些进程的资源供其他进程使用。
4.5死锁避免算法:银行家算法;4.5.1 安全与不安全状态;若在某一时刻,系统能按某种顺序如<P1,P2,…,Pn>来为每个进程分配其所需的资源,直至最大需求,使每个进程都可顺利地完成,则称此时的系统状态为安全状态;称<P1,P2,…,Pn>为安全序列。
若某个时刻系统中不存在这样一个安全序列,则称此时的系统状态为不安全状态。
4.5.2 安全性算法;系统所执行的安全性算法描述:⑴设置两个向量·Work 它表示系统可提供给进程继续运行的各类资源数目,它含有m个元素,开始执行安全性算法时,Work = Available;·Finish 它表示系统是否有足够的资源分配给进程,使之运行完成,开始时,Finish(i)=false;当有足够资源分配给进程Pi时,令Finish(i)=true。
⑵从进程集合中找到一个能满足下述条件的进程:· Finish(i) = = false;· Need(i) <= Work;如找到则执行步骤(4);否则,执行步骤(4)。
(4)当进程Pi获得资源后,可顺利执行直到完成,并释放出分配给它的资源,故应执行:Work = Work + Allocation(i);Finish(i) = true;转步骤(2);(4)若所有进程的Finish(i)都为true,则表示系统处于安全状态;否则,系统处于不安全状态。
4.5.3 银行家算法;在描述银行家算法之前,首先得定义几个关键向量:(1)可利用资源向量Available,它是一个含有m个元素的数组,其中的每一个元素代表一类可利用资源的数目,其初值是系统中所配置的该类全部可利用资源数目。
其数值随该类资源的分配和回收而动态地改变;(2)最大需求矩阵Max,如Max(i,j) = k,表示进程I需要的j 类资源的最大数目是k;(3)分配矩阵Allocation, Allocation(i,j) = k, 表示进程i当前已分到的j类资源的数目为k;(4)需求矩阵Need,Need(i,j) = k,表示进程i还需要j类资源k 个,才能正确执行完成。
上述的矩阵存在如下的关系:Need( i , j ) = Max( i , j ) – Allocation ( i , j )银行家算法的描述如下:Request(i)是进程Pi的请求向量。
Request(i,j) = k 表示进程Pi请求分配j类资源的数目是k 个。
当Pi发出请求后,系统按下述步骤进行检查:(1)如果Requet( i ) <=Need,则转向步骤(2);否则,认为出错,因为它所需要的资源数目已超过它所宣布的最大值;(2)如果Request( i ) <=Available,则转向步骤(4);否则,表示系统中尚无足够的资源满足Pi的申请,Pi必须等待;(3)系统试探把资源分配给进程Pi,并修改下面数据结构中的数值:Available = Available – Request(i);Allocation(i) = Allocation(i) + Request(i);Need( i ) = Need( i ) – Request (i);(4) 系统执行安全性算法,检查此次资源分配后,系统是否处于安全状态,若安全,才正式将资源分配给进程Pi,以完成本次分配;否则,将试探分配作废,恢复原来的资源分配状态,让进程Pi等待。
五实验过程5.1程序流程说明:程序一开始会让用户输入各类资源总数,然后要求输入各类需求数,本地资源数,接着要求用户输入请求资源分配的的进程号,程序接受了以上的输入以后,会先进行试分配,如果可以完成,则出现:“进程安全!”的提示,否则出现:“进程不安全!”并将先前已经分配的资源还原!以下为程序的源代码和详细的说明:#include<stdio.h>main(){ int i,j,x=0;int r[3],max[5][3],allocation[5][3],need[5][3],avaiable[3],sub[3],request[5][3],q[3],p;printf("请输入各类资源总数:");for(j=0;j<3;j++)scanf("%d",&r[j]);printf("请输入各类最大需求数:");//////maxfor(i=0;i<5;i++)for(j=0;j<3;j++)scanf("%d",&max[i][j]);printf("请输入本地拥有资源数:");/////allocationfor(i=0;i<5;i++)for(j=0;j<3;j++)scanf("%d",&allocation[i][j]);for(i=0;i<5;i++)for(j=0;j<3;j++)need[i][j]=max[i][j]-allocation[i][j];///////计算每一个进程现在还需要多少的资源for(j=0;j<3;j++){ sub[j]=0;for(i=0;i<5;i++)sub[j]=sub[j]+allocation[i][j];avaiable[j]=r[j]-sub[j] ; }///////计算每类资源还剩余多少printf("请输入进程号:");scanf("%d",&p);///////////以上为用户输入过程start: for(j=0;j<3;j++)scanf("%d",&request[p][j]);for(j=0;j<3;j++)q[j]=need[p][j]-request[p][j];for(j=0;j<3;j++){if(q[j]>0||q[j]==0)++x;}if(x!=3){printf("您输入错误,请重新输入:");goto start;}if(!daxiao(p,avaiable,request))printf("请稍等……");elsefor(j=0;j<3;j++){avaiable[j]=avaiable[j]-request[p][j];allocation[p][j]=allocation[p][j]+request[p][j];need[p][j]=need[p][j]-request[p][j];}/////////////////////////以下为探测是否安全if(safe(need,avaiable,allocation)){ printf("进程安全\n");printf("本地拥有资源数:\n") ;for(i=0;i<5;i++){for(j=0;j<3;j++)printf("%5d",allocation[i][j]);printf("\n");}printf("需要资源数:\n");for(i=0;i<5;i++){for(j=0;j<3;j++)printf("%5d",need[i][j]);printf("\n");}printf("剩余资源::\n");for(j=0;j<3;j++)printf("%5d",avaiable[j]); }elseprintf("进程不安全");for(j=0;j<3;j++){avaiable[j]=avaiable[j]+request[p][j];allocation[p][j]=allocation[p][j]-request[p][j];need[p][j]=need[p][j]+request[p][j] ; } }////////将试分配的资源还原//////////////////////////////////////////daxiao(a,array1,array2)int a, array1[3],array2[5][3] ;{ int c,d=0,q[3];for(c=0;c<3;c++)q[c]=array1[c]-array2[a][c];for(c=0;c<3;c++)if(q[c]>=0)++d;if(d==3)return 1;else return 0;}//////////////////////////////////safe(array3,array4,array5)int array3[5][3],array4[3],array5[5][3];{ int i,j,e=0,z,x,work[3],finish[5],s[5];for(j=0;j<3;j++)work[j]=array4[j] ;for(i=0;i<5;i++)finish[i]=0;z=0,x=0,i=0;for(i=0;i<5;i=(++i)%5){ if(finish[i]==0&&daxiao(i,work,array3)){ for(j=0;j<3;j++)work[j]=work[j]+array5[i][j];finish[i]=1;s[z++]=i; x=0;}else { x++;if(x>6) break; }}for(i=0;i<5;i++){ if(finish[i]==1)++e;}if(e==5)return 1;elsereturn 0; }通过测试,以上程序完全可以达到实验要求,它适合演示3种资源5个进程分配的情况。