操作系统的课程设计银行家算法模拟实现.docVIP

操作系统的课程设计银行家算法模拟实现.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统的课程设计银行家算法模拟实现

操作系统原理 课程设计 课设名称: 银行家算法模拟实现 姓 名: 郝碧涛 班 级: 13软件3班 学 号: 1310321308 指导教师: 万方 一.设计题目 银行家算法模拟实现 二.主要内容 设计目的 了解多道程序系统中,多个进程并发执行的资源分配。 掌握思索的产生原因、产生死锁的必要条件和处理死锁的基本方法。 掌握预防死锁的方法,系统安全状态的基本概念。 掌握银行家算法,了解资源在进程并发执行中的资源分配策略。 理解死锁避免在当前计算机系统不常使用的原因。 银行家算法的概念 银行家算法是一种最有代表性的避免死锁的算法。在避免死锁方法中允许进程动态地申请资源,但系统在进行资源分配之前,应先计算此次分配资源的安全性,若分配不会导致系统进入不安全状态,则分配,否则等待。为实现银行家算法,系统必须设置若干数据结构。要解释银行家算法,必须先解释操作系统安全状态和不安全状态。 安全序列是指一个进程序列{P1,…,Pn}是安全的,即对于每一个进程Pi(1≤i≤n),它以后尚需要的资源量不超过系统当前剩余资源量与所有进程Pj (j i )当前占有资源量之和。 #define w 50 //宏定义 #define r 50 //宏定义 int m; //总进程数 int all[w];//各种资源的数目总和 int max[w][r]; //m个进程最大资源需求量 int available[r]; //系统可用资源数 int allocation[w][r]; //m个进程已经得到资源的资源量 int need[w][r]; //m个进程还需要资源的资源量 int request[r]; //请求资源个数 3.详细设计 3.1算法思想 银行家算法的基本思想是分配资源之前,判断系统是否是安全的;若是,才分配。否则拒绝分配。 3.2银行家算法 设Request[n],是进程的请求向量,如果Request[n]=m,则表示该进程需要m个资源。当该进程发出资源请求后,系统按下述步骤进行检查: (1)如果Request[n]Need[i,n],则。 (2)如果Request[n]Available,则进程i进入等待资源状态,返回。 (3)假设进程i的申请已获批准,于是修改: Available=Available-Request Allocation=Allocation+Request Need=Need-Request (4)系统执行安全性检查,如安全,则分配成立;否则,系统恢复原状,进程等待。 { int i=0,j=0; char flag=Y; while(flag==Y||flag==y) { i=-1; while(i0||i=m) { cout 请输入需申请资源的进程号(从0到m-1):; cini; if(i0||i=m)cout 该进程号不存在,请重新输入!endl; } cout 请输入进程i申请的资源数:; for (j=0;j1;j++) { cout ; cinrequest[j]; if(request[j]need[i][j]) //若请求的资源数大于进程还需要i类资源的资源量j { cout 进程i申请的资源数大于进程i还需要资源的资源量!; cout申请不合理,请重新选择!endlendl; flag=1; break; } else { if(request[j]available[j]) //若请求的资源数大于可用资源数 { cout 进程i申请的资源数大于系统可用资源的资源量!; cout申请不合理!请重新选择!endlendl; flag=1; break; } } } if(flag==Y||flag==y) { change(i); //调用change(i)函数,改变资源数 if(chkerr(i)) //若系统安全 { rstore(i); //调用rstore(

文档评论(0)

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

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

1亿VIP精品文档

相关文档