死锁的避免--银行家算法.docVIP

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

实验三死锁的防止――银行家算法

实验目的

掌握死锁产生的原因。

掌握银行家算法。

能使用高级语言模拟实现银行家算法。

相关数据结构

可利用资源向量Available,它是一个含有m个元素的数组,其中的每一个元素代表一类可利用的资源的数目,其初始值是系统中所配置的该类全部可用资源数目。其数值随该类资源的分配和回收而动态地改变。如果Available[j]=k,标是系统中现有j类资源k个。

最大需求矩阵Max,这是一个n×m的矩阵,它定义了系统中n个进程中的每一个进程对m类资源的最大需求。如果Max[i][j]=k,表示进程i需要j类资源的最大数目为k。

分配矩阵Allocation,这是一个n×m的矩阵,它定义了系统中的每类资源当前分配到每一个进程的资源数。如果Allocation[i][j]=k,表示进程i当前已经分到j类资源的数目为k个。Allocation[i]表示进程i的分配向量。

需求矩阵Need,这是一个n×m的矩阵,用以表示每个进程还需要的各类资源的数目。如果Need[i][j]=k,表示进程i还需要j类资源k个,才能完成其任务。Need[i]表示进程i的需求向量。

上述三个矩阵间存在关系:Need[i][j]=Max[i][j]-Allocation[i][j];

银行家算法

Request是进程i的请求向量。Request[j]=k表示进程i请求分配j类资源k个。当进程i发出资源请求后,系统按下述步骤进行检查:

如果Request≤Need[i],那么转向步骤2;否那么,认为出错,因为它所请求的资源数已超过它当前的最大需求量。

如果Request≤Available,那么转向步骤3;否那么,表示系统中尚无足够的资源满足进程i的申请,进程i必须等待。

系统试探性地把资源分配给进程i,并修改下面数据结构中的数值:

Available=Available-Request

Allocation[i]=Allocation[i]+Request

Need[i]=Need[i]-Request

系统执行平安性算法,检查此次资源分配后,系统是否处于平安状态。如果平安才正式将资源分配给进程i,以完本钱次分配;否那么,将试探分配作废,恢复原来的资源分配状态,让进程i等待。

平安性算法

设置两个向量。

Work:它表示系统可提供应进程继续运行的各类资源数目,它包含m个元素,开始执行平安性算法时,Work=Available。

Finish:它表示系统是否有足够的资源分配给进程,使之运行完成,开始Finish[i]=false;当有足够资源分配给进程i时,令Finish[i]=true;

从进程集合中找到一个能满足下述条件的进程。

Finish[i]==false;

Need[i]≤work;

如找到那么执行步骤3;否那么,执行步骤4;

当进程i获得资源后,可顺利执行直到完成,并释放出分配给它的资源,故应执行

Work=work+Allocation[i]

Finish[i]=true;转向步骤2;

假设所有进程的Finish[i]都为true,那么表示系统处于平安状态;否那么,系统处于不平安状态。

实验内容

设计有n个进程共享m个系统资源的系统,进程可动态的申请和释放资源,系统按各进程的申请动态的分配资源。

系统能显示各个进程申请和释放资源,以及系统动态分配资源的过程,便于用户观察和分析;

程序框架已经给出〔见附件〕,要求将平安性算法补充完整。

源程序代码:

//*********************************************************************************************//

//*实验三死锁的防止――银行家算法*//

//* *//

//*本程序需要预先设置三个文件:Available_list.txt,Max_list.txt,Allocation_list.txt*//

//*各文件格式如下: *//

//*Available_list.txt *//

//*3//表示共有3类资源 *//

//*1057//表示各类资源的初始可用个数,即Available[0]=10,Available[1]=5 *//

//*

文档评论(0)

liuzhouzhong + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档