ImageVerifierCode 换一换
格式:DOC , 页数:33 ,大小:267.50KB ,
资源ID:2686319      下载积分:10 金币
验证码下载
登录下载
邮箱/手机:
验证码: 获取验证码
温馨提示:
支付成功后,系统会自动生成账号(用户名为邮箱或者手机号,密码是验证码),方便下次登录下载和查询订单;
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/2686319.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  
声明  |  会员权益     获赠5币     写作写作

1、填表:    下载求助     留言反馈    退款申请
2、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
3、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
4、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
5、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【可****】。
6、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
7、本文档遇到问题,请及时私信或留言给本站上传会员【可****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。

注意事项

本文(毕业论文-行银家算法避免死锁的研究与实现.doc)为本站上传会员【可****】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4008-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

毕业论文-行银家算法避免死锁的研究与实现.doc

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!=

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服