1、长治学院学士学位论文(设计)长 治 学 院2013届学士学位毕业论文银行家算法避免死锁的研究与实现学 号: 09407227 姓 名: 王子丹 指导教师: 陕粉丽 专 业: 计算机科学与技术 系 别: 计算机系 完成时间:2013年5月银行家算法避免死锁的研究与实现专业:计算机科学与技术 姓名:王子丹 学号:09407227指导教师:陕粉丽摘 要:Dijkstra的银行家算法是最有代表性的避免死锁的算法,该算法由于能用于银行系统现金贷款的发放而得名。银行家算法是在确保当前系统安全的前提下推进的。对进程请求先进行安全性检查,来决定资源分配与否,从而确保系统的安全,有效的避免了死锁的发生。该论文在
2、理解和分析了银行家算法的核心思想以及状态的本质含义的前提下,对算法的实现在总体上进行了设计,包括对算法分模块设计,并对各个模块的算法思想通过流程图表示,分块编写代码,并进行测试,最后进行程序的测试,在设计思路上严格按照软件工程的思想执行,确保了设计和实现的可行性。 关键词:银行家算法;死锁;避免死锁;安全性序列I目 录1 前言11.1 课题背景11.2 死锁11.3 系统安全状态21.4 银行家算法22 需求分析32.1 问题描述32.2 基本要求32.3 数据流模型33 概要设计43.1 模块的划分43.2 模块调用关系43.3 各模块之间的接口43.4 程序流程图54 详细设计64.1 数
3、据结构选取分析64.2 数据结构设计64.3 算法整体设计与调用64.4 程序流图75 程序分析测试95.1 分模块分析与测试95.2 集成测试116 结论12参考文献12致谢14附录15II银行家算法避免死锁的研究与实现1 前言1.1 课题背景在多道程序系统中,虽可以借助多个进程的并发执行来改善系统的资源利用率,提高系统吞吐量,但可能发生一种危险死锁。如此,寻求一种避免死锁的方法便显得很重要。死锁产生的一般原因有两点:竞争资源和进程间推进顺序非法。因此,我们只需在当前的有限资源下,找到一组合法的执行顺序,便能很好的避免死锁。而银行家算法起源于银行系统的发放贷款,和计算机操作系统的资源分配完全
4、符合,因此可以借鉴该算法的思想,设计出一种有效的算法程序,解决该问题。1.2 死锁死锁是进程死锁的简称,是指多个进程循环等待它方占有的资源而无限期地僵持下去的局面。很显然,如果没有外力的作用,那么死锁涉及到的各个进程都将永远处于封锁状态。虽然进程在运行过程中会产生死锁,但死锁的发生也必须具备四个条件:(1)互斥条件;(2)请求与保持条件;(3)不剥夺条件;(4)环路与等待条件。为保证系统中诸进程的正常运行,应事先采取必要的措施,来预防发生死锁。目前,预防死锁的方法可归结为以下两种:(1)预防死锁。它是通过设置某些限制条件。去破坏产生死锁的四个条件中的一个或几个条件,来预防发生死锁。(2)避免死
5、锁。同样是实现预防的策略但是他并不是实现采取各种限制措施去破坏产生死锁的四个条件,而是在资源分配过程中,用某种方法去防止系统进入不安全的状态,从而避免死锁。(3)检测死锁。这种方法并不须事先采取任何限制性措施,也不需检查系统是否进入不安全区,而是允许系统在运行过程中发生死锁。通过系统设置的检测机构,及时的检测出死锁的发生。然后,采取适当的手段,将死锁清除掉。(4)解除死锁。与检测死锁相配套,当系统发生死锁的时候,将进程从死锁中解除出来。1.3 系统安全状态预防死锁和解除死锁都是通过施加条件限制,来预防发生死锁。但预防死锁所施加的条件较严格,这往往会影响进程的并发执行,而避免死锁所施加的限制条件
6、则较宽松,这给进程的运行提供了较宽松的环境,有利于进程的并发执行。要想避免死锁,就必须考虑进程是否处于安全状态,只要处于安全状态就可以避免死锁。所谓的安全状态就是指系统按某种进程顺序(P1,P2,Pn)(称为安全序列),来为某种进程分配资源,直至满足每个进程对资源的最大需求,使每个进程都能够顺利完成。但如果系统无法找到这样一个安全序列,则称系统处于不安全状态。1.4 银行家算法银行家算法是最具有代表性的避免死锁的算法,是由于该算法能用于银行系统现金贷款的发放而得名。我们可以把操作系统看作是银行家,操作系统管理的资源相当于银行家管理的资金,进程向操作系统请求分配资源相当于用户向银行家贷款。为保证
7、资金的安全,银行家规定:(1)当一个顾客对资金的最大需求量不超过银行家现有的资金时就可接纳该顾客;(2)顾客可以分次贷款,但贷款的总数不能超过最大需求量;(3)当银行家现有的资金不能满足顾客尚需的贷款数额时,对顾客的贷款可推迟支付,但总能使顾客在有限的时间里得到贷款;(4)当顾客得到所需的资金后,一定能在有限的时间里归还所有的资金。操作系统按照银行家制定的规则为进程分配资源,当进程首次申请资源时,要测试该进程对资源的最大需求量,如果系统现存的资源可以满足它的最大需求量则按当前的申请量分配资源,否则就推迟分配。当进程在执行中继续申请资源时,先测试该进程已占用的资源数与本次申请的资源数之和是否超过
8、了该进程对资源的最大需求量。若超过则拒绝分配资源,若没有超过则再测试系统现存的资源能否满足该进程尚需的最大资源量,若能满足则按当前的申请量分配资源,否则也要推迟分配。那么,安全序列在银行家算法中的实际意义在于:系统每次进行资源分配后,如果对于系统中新的资源状况,存在一个安全序列,则至少存在一条确保系统不会进入死锁的路径。2 需求分析2.1 问题描述运用银行家算法避免死锁的发生是在确保当前系统安全的前提下推进的,对进程请求先进行安全性检查来决定资源分配与否,从而确保系统的安全,有效的避免了死锁的发生。问题的关键在于安全性算法,即查找安全性序列。2.2 基本要求(1)从键盘输入当前系统的资源信息,
9、包括当前可用资源,每个进程对各类资源的最大需求量,每个进程当前已分配的各个资源量和每个进程尚需要的各个资源量;(2)输入进程请求,按照设计好的安全性算法进行检查,得到结果并输出整个执行过程的相关信息和最终结果;(3)要求要有各种异常的处理,程序的可控制性和可连续性执行。包括对进程的存在有无检查,请求向量的不合法检查,试分配失败后的数据恢复和重新接受进程请求等。 2.3 数据流模型用键盘输入信息,对系统资源初始化,输入进程请求,用安全性算法进行安全性检查,系统安全的话就进行试分配,再进行安全性检查;如果试分配失败则恢复系统。如图1所示。初始化安全性检查输出结果输入信息试分配安全性检查图1 数据流
10、模型3 概要设计3.1 模块的划分由于该算法规模较小,所以选用结构化的设计方法,将该系统划为四块,分别是:(1)主模块,处在整个系统的最高层,负责组织调用其他模块;(2)初始化模块,负责从键盘读入系统资源和进程状态,并将系统初识资源分配状态打印;(3)试分配模块,负责处理进程请求和相应的数据结构的修改,以及特殊情况的处理;(4)安全性检查,负责试分配后的安全性检查,以及系统不安全时的资源恢复。3.2 模块调用关系银行家算法系统有四个模块,各模块之间的调用关系如图2所示:主模块 Main()初始化 Init_process()试分配Attempt_Allocation()安全性检查 Safety
11、_Algorithm()图2 模块调用关系图3.3 各模块之间的接口系统的四个模块用到三个接口。分别为Flag1,pro,Flag2。它们的功能介绍如下:29长治学院学士学位论文(设计)Flag1:试分配模块Attempt_Allocation与安全性检查Safety_Algorithm之间接口Attempt_Allocation通过检查 flag的真假了判断是否执行。Pro:一个地址,Safety_Algorithm返回给主模块main的信息,不为NULL时表示试分配成功,否则系统转入相应异常处理。Flag2:Safety_Algorithm与主模块之间的接口,为真则调用打印函数,输出最终结
12、果,否则调用恢复函数,恢复之前系统状态。3.4 程序流程图假设Request是进程的请求向量,Need是需求向量,Available是可利用资源向量。如果RequestjNeedi,j,则认为出错,进入等待状态。因为它所需要的资源数已经超得过最大值,否则判断Requestj,Availablej。如果RequestjAvailablej,则表示尚无足够资源,进程需要等待。接着,系统试探着把资源分配给进程,系统执行安全性算法。检查此次分配后系统是否处于安全状态。若安全,才正式将资源分配给进程,来完成分配。否则,将本次的试探分配作废,恢复原来的资源分配。具体程序总流程图如图3所示。YYYN开始结束
13、申请资源试探分配安全性算法进程等待正式分配恢复程序RENE?REnum;i=0;Worki=availi;对不同情况进行分析P!=null?im? 图6 试分配的程序流程图 图5 安全性算法的程序流程图 (3)接受进程请求,试分配的程序流程图首先,p指针指向弧的结点。如果为空,则输出无此进程,然后,输入请求向量,检查合法性,进行试分配。如图6所示。(4)对试分配后的系统,进行安全性检查的程序流程图和图5大致一样,唯一一点在于当找不到安全序列时,将本次试分配作废,恢复该次试分配之前的数据结构。如图7所示。开始Int i;i=0i m?m?NY恢复系统资源i +;结束图7 试分配后,安全性检查的程
14、序流程图5 程序分析测试5.1 分模块分析与测试(1)初始化系统资源模块Init_process的测试图8 初始化系统资源模块Init_process的测试 按提示输入,以-1结束整个初始化过程,并打印结果。起初效果不理想,经过一些调整后,显示才比较理想。如图8所示。(2)试分配模块Attempt_Allocation的测试 图9 试分配模块Attempt_Allocation的测试试分配模块,主要是在系统进入第一次安全检查后,对系统资源的一次尝试性分配,试分配完成后,相关的数据结构被修改。如图9所示。(3)安全模块Safety_Algorithm的调试试分配前的安全算法,结果如果输出一个安全
15、性序列,并且经过人工检查该安全性序列,确实有效,则该模块正确,如图10所示;如果系统不安全,打印出相关信息,返回上一层。如图11所示。图10 安全模块Safety_Algorithm的调试的安全状态图11 安全模块Safety_Algorithm的调试的不安全状态 试分配后的安全算法,结果如果输出一个安全性序列,并且经过人工检查该安全性序列,确实有效,则该模块正确,如图12所示;否则,之前的试分配作废,恢复试分配前的资源状态。如图13所示。图12 试分配后输出一个安全性序列图13 试分配后不安全状态的资源恢复5.2 集成测试 各模块测试通过后,集成在一起测试,系统初始资源和模块测试时保持一致,
16、以下是测试用例以及结果,基本包括了该算法的所有情况。(1)06: 结果: 无此进程。(2)01: Request(2,0,2)结果: 系统不能满足。(3)01: Request(1,0,2)结果: 两次安全性检查都通过,并打印出最终结果。(4)00: Request(0,2,0)结果: 试分配后,系统不安全,试分配作废。(5)00: Request(0,1,0)结果: 两次安全性检查都通过,并打印出最终结果。6 结论银行家算法避免死锁的研究与实现作为我的毕业设计。首先,我在网上收集了一些关于银行家算法的资料,包括它的起源,以及在实际中多个领域的应用,加深了对它的理解。之后,确定自己设计的算法分
17、四大模块。首先需要初识化系统资源;其次,安全性检查;再者,试分配;最后是试分配后的安全性检查。在程序测试中出现了很多问题。譬如,死循环,逻辑关系的设计不当,还有显示效果不理想等等。但通过查阅书本,对算法细节重新建立正确的认识后,再通过单步调试后,最终解决。在集成测试中,由于之前的模块测试做的比较扎实,所以相对只是一些细节上的问题,很快也达到了预期的效果。 参考文献1 严蔚敏,吴伟民.数据结构(C语言版)M.北京:清华大学出社,2005. 2 汤小丹,梁红兵,哲凤屏等.计算机操作系统(第三版)M.西安:西安电子科技大学出版社,2007.3 谭浩强.C语言程序设计M.北京:清华大学出版社,2006
18、.4 于帆,赵妮.程序设计基础M.北京:清华大学出版社,2006.5 罗宇.操作系统课程M.北京:设计机械工业出版社,2005.6 黄水松,黄干平,曾平.计算机操作系统M.武汉:武汉大学出版社,2003.7 鞠时光.操作系统原理M.武汉:武汉理工大学出版社,2003.8 何炎祥,熊前兴.操作系统原理M.武汉:华中科技大学出版社,2001.9 张丽芬,刘美华.操作系统原理教程M.北京:电子工业出版社,2004.10 陈火.数据结构与算法M.广东:中山大学出版社,2009.11 郑扣根.操作系统概念(第七版)M.北京:高等教育出版社,1992.12 赵莉,杨国梁,孙喁喁,徐飞.Java程序设计教程
19、M.西安:西安科技大学出版社,2009.13 陈向群,向勇,王雷.Windows操作系统原理(第二版)M.北京:北京机械工业出版社,2004.Bankers Algorithm To Avoid Deadlock Research and Implementation Major:Computer Science and technology Name: Wang Zidan Student ID: 09407227 Supervisor:Shan FenliAbstract:Bankers algorithm what Dijkstra put forward is the most rep
20、resentative of the algorithm to avoid deadlock, this algorithm can be used for the banking system because of its cash loans. Bankers algorithm is advancing in the premise of ensuring the system security. The first is that security check to process requests, to determine the allocation of resources o
21、r not, so as to ensure the safety of the system, to avoid deadlock.This paper on the understanding and analysis of the essential meaning of bankers algorithm as well as the state of the core idea, the algorithm is implemented in the overall design, including the module design of algorithm, and the a
22、lgorithm of each module through a flow chart, block coding, and testing, the final program in the test, the design ideas on strictly according to the thought of software engineering implementation, to ensure that the design and implementation of feasible, credible.Keywords: bankers algorithm; deadlo
23、ck; avoid deadlock; secure sequence致谢在论文的写作过程中遇到了无数的困难和障碍,都在同学和老师的帮助下度过了。尤其要感谢我的论文指导老师陕粉丽老师,她对我进行了无私的指导和帮助,不厌其烦的帮助进行论文的修改和改进。另外,在校图书馆查找资料的时候,图书馆的老师也给我提供了很多方面的支持与帮助。在此向帮助和指导过我的各位老师表示最真诚的感谢! 此外,还要感谢我的同学和朋友,在我写论文的过程中给予我很多素材,还在论文的撰写和排版的过程中提供热情的帮助。 由于我的学术水平有限,所写论文难免有不足之处,恳请各位老师批评和指正!附录/银行家算法#include#incl
24、ude#include#define M 3#define N 10#define D12 %5d%5d%5d%5d%5d%5d%5d%5d%5d%5d%5d%5d typedef struct my_process int num; int MaxM; int AllocationM; int NeedM; struct my_process* next;process;void Insret_Tail(process *head,process node) process* p=(process*)malloc(sizeof(process);process* last=NULL;memc
25、py(p,&node,sizeof(process); p-next=NULL;if(NULL=*head)*head=p;else last=*head;while(last-next!=NULL)last=last-next;last-next=p;void Init_process(process *head,int m,int* count)int i,j=0;process node;printf(请初始化一组进程,进程编号从P0开始,输入-1 结束输入:n);donode.num=j+;printf(请输入第 %d个进程信息 :n,node.num);printf(最大需求矩阵:
26、);scanf(%d,&node.MaxP0);if(node.MaxP0!=-1) for(i=1;im;i+)scanf(%d,&node.Maxi);printf(分配矩阵: );for(i=0;im;i+)scanf(%d,&node.Allocationi);printf(需求矩阵: );for(i=0;im;i+)scanf(%d,&node.Needi);Insret_Tail(head,node);(*count)+;elsebreak;while(1);void Print(process *head,int *avail,int m)process* p=NULL;int
27、i,j;char ch;p=head;if(NULL=p)printf(当前无进程 !n); exit(0);elseprintf(| Process | Max | |Allocation| | Need | |Available|nn);printf(t);for(i=0;i4;i+)ch=A;for(j=0;jnum);for(j=0;jMaxj);printf(t);for(j=0;jAllocationj);printf(t);for(j=0;jNeedj);printf(t);for(j=0;jnext;puts();process* Location(process* head,
28、int pro_num)process *p=NULL;p=head;if(NULL=p)printf(error !n);return p;elsewhile(p!=NULL)if(p-num=pro_num)break;elsep=p-next;if(NULL=p)printf(无此进程 !n);return p;else return p;process* Attempt_Allocation(process* head,int *request,int *avail,int m)int num,i;process* p=NULL;printf(请输入进程编号: n);scanf(%d,
29、&num);p=Location(head,num);if(p=NULL)printf(无此进程!n);return p;printf(请输入该进程的请求向量: n);for(i=0;im;i+)scanf(%d,&requesti);for(i=0;im;i+)if(requestiNeedi);elseprintf(该请求系统不能满足 !n);return NULL;for(i=0;im;i+)if(requesti=availi);elseprintf(该请求系统不能满足 !n);return NULL;for(i=0;iAllocationi=p-Allocationi + reque
30、sti;p-Needi=p-Needi - requesti;return p;process* Reasonable(process* head,int*finish,int*work,int m,int n)int i=0,j=0,count=0;process* p=NULL;while(1)if(finishi!=-1)p=Location(head,finishi);if(p!=NULL)for(j=0;jNeedjworkj)break;elsecontinue;if(j=m)return p;elsei+; elsei+; if(i=n)return NULL; void Alt
31、er_Data(process* p,int* work,int* finish,int recordM,int m) int i;for(i=0;inumi=worki;worki=worki+p-Allocationi;finishp-num=-1; int Safety_Algorithm(process* head,int *avail,int *safety,int RecordM,int m,int n)int *work=NULL;int *finish=NULL;process *p=NULL;process *pro=NULL;int i,count=0;work=(int*
32、)malloc(m*sizeof(int);finish=(int*)malloc(n*sizeof(int);/safety=(int*)malloc(n*sizeof(int);p=head;for(i=0;inum;p=p-next;i+;i=0;while(countnum; /i+;elseprintf(当前系统处于不安全状态 !n);/remark=1;break;if(count=n)printf(当前系统处于安全状态,存在一个安全序列 :n);for(i=0;in;i+)printf(%d,safetyi); puts();free(finish);free(work);fin
33、ish=NULL;work=NULL;if(count=n)return 1; elsereturn 0;void Return_Source(process* p,int *request,int *avail,int m) int i;for(i=0;iAllocationi-=requesti; p-Needi+=requesti; availi+=requesti;void Print_After_Safety(process *head,int *safety,int workM,int m,int n) process* p=NULL;int i,j;char ch;p=head;if(NULL=p)exit(0);elseprintf(| Process | Work | | Need | |Allocation| |Work+Allocation| | Finish |nn);printf(t);for(i=0;i4;i+)ch=A;for(j=0;jm;j+)printf(%4c,ch+);printf(t);puts();for(i=0;in;i+)p=head;while(p!=
©2010-2025 宁波自信网络信息技术有限公司 版权所有
客服电话:4008-655-100 投诉/维权电话:4009-655-100