银行家算法课程设计报告材料.doc

银行家算法课程设计报告材料.doc

ID:56526085

大小:211.50 KB

页数:34页

时间:2020-06-27

银行家算法课程设计报告材料.doc_第1页
银行家算法课程设计报告材料.doc_第2页
银行家算法课程设计报告材料.doc_第3页
银行家算法课程设计报告材料.doc_第4页
银行家算法课程设计报告材料.doc_第5页
资源描述:

《银行家算法课程设计报告材料.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、银行家算法一.需求分析1.在多道程序系统中,多个进程的并发执行来改善系统的资源利用率,提高系统的吞吐量,但可能发生一种危险——死锁。所谓死锁(Deadlock),是指多个进程在运行过程中因争夺资源而造成的一种僵局(DeadlyEmbrace),当进程处于这种状态时,若无外力作用,他们都无法在向前推进。  要预防死锁,有摒弃“请求和保持”条件,摒弃“不剥夺”条件,摒弃“环路等待”条件等方法。 但是,在预防死锁的几种方法之中,都施加了较强的限制条件;而在避免死锁的方法中,所施加的限制条件较弱,有可能获得令人满意的系统性能。在该方法中把系统状态分为安全状态和不安全状态,便可避免死

2、锁的发生。 而最具代表性的避免死锁的算法,便是Dijkstra的银行家算法。 利用银行家算法,我们可以来检测CPU为进程分配资源的情况,决定CPU是否响应某进程的的请求并为其分配资源,从而很好避免了死锁的产生。2.银行家算法是一种最有代表性的避免死锁的算法。   要解释银行家算法,必须先解释操作系统安全状态和不安全状态。   安全状态:如果存在一个由系统中所有进程构成的安全序列P1,„,Pn,则系统处于安全状态。安全状态一定是没有死锁发生。   不安全状态:不存在一个安全序列。不安全状态不一定导致死锁。   那么什么是安全序列呢? 安全序列:一个进程序列{P1,„,Pn}是

3、安全的,如果对于每一个进程Pi(1≤i≤n),它以后尚需要的资源量不超过系统当前剩余资源量与所有进程Pj (j < i )当前占有资源量之和。   银行家算法: 我们可以把操作系统看作是银行家,操作系统管理的资源相当于银行家管理的资金,进程向操作系统请求分配资源相当于用户向银行家贷款。操作系统按照银行家制定的规则为进程分配资源,当进程首次申请资源时,要测试该进程对资源的最大需求量,如果系统现存的资源可以满足它的最大需求量则按当前的申请量分配资源,否则就推迟分配。当进程在执行中继续申请资源时,先测试该进程已占用的资源数与本次申请的资源数之和是否超过了该进程对资源的最大需求量。

4、若超过则拒绝分配资源,若没有超过则再测试系统现存的资源能否满足该进程尚需的最大资源量,若能满足则按当前的申请量分配资源,否则也要推迟分配。3.设计要求:设计一n个并发进程共享m个系统资源的程序实现银行家算法。要求包括: (1) 简单的初始化界面; (2) 系统资源的占用和剩余情况; (3) 为进程分配资源,用银行家算法对其进行检测,分为以下三种情况:        A. 所申请的资源大于其所需资源,提示分配不合理不予分配并返回;         B. 所申请的资源未大于其所需资源,但大于系统此时的可利用资源,提示分配不合理不予分配并返回;  C. 所申请的资源未大于其所需资

5、源,亦未大于系统此时的可利用资源,预分配并进行安全性检查:        a. 预分配后系统是安全的,将该进程所申请的资源予以实际分配并打印后返回;        b. 与分配后系统进入不安全状态,提示系统不安全并返回; (4) 对输入进行检查,即若输入不符合条件,应当报错并返回重新输入; (5) 撤销作业,释放资源。二.概要设计(一)算法思路:先对用户提出的请求进行合法性检查,即检查请否大于需要的,是否大于可利用的。若请求合法,则进行预分配,对分配后的状态调用安全性算法进行检查。若安全,则分配;若不安全,则拒绝申请,恢复到原来的状态,拒绝申请。(二)算法步骤:(1)如果R

6、equesti<or =Need,则转向步骤(2);否则,认为出错,因为它所需要的资源数已超过它所宣布的最大值。 (2)如果Request<or=Available,则转向步骤(3);否则,表示系统无足够的资源,进程必须等待。 (3)系统试探把要求的资源分配给进程Pi,并修改下面数据结构中的值:Available=Available-Request[i];      Allocation=Allocation+Request;   Need=Need-Request; (4)系统执行安全性算法,检查此次资源分配后,系统是否处于安全状态。三.详细设计#defineSIZE11

7、intavailable[SIZE];intclaim[SIZE][SIZE];intallocation[SIZE][SIZE];intneed[SIZE][SIZE];intrequest[SIZE][SIZE]={0};//记录某个进程申请各个资源类中的资源实例的数量intfinish[SIZE]={0};//工作变量,用于判断进程是否已经执行过,初始状态全部为0,即未执行intp[SIZE];//记录序列执行顺序intava;//记录系统有多少个资源类intprocess;//记录进程数量intr;//记录

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。