欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    操作系统银行家算法(7页).doc

    • 资源ID:36343137       资源大小:335KB        全文页数:7页
    • 资源格式: DOC        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    操作系统银行家算法(7页).doc

    -操作系统 银行家算法操作系统实验报告实验目标1. 理解银行家算法。2. 掌握进程安全性检查的方法及资源分配的方法。3. 加深了解有关资源申请、避免死锁等概念。4. 体会和了解死锁和避免死锁的具体实施方法。实验要求编写和调试一个系统动态分配资源的简单模拟程序,观察死锁产生的条件,并采用银行家算法,有效的防止和避免死锁的发生。设计思路1.银行家算法在避免死锁的方法中,如果施加的限制条件较弱,有可能获得令人满意的系统性能。在该方法中把系统的状态分为安全状态和不安全状态,只要能使系统始终都处于安全状态,便可以避免发生死锁。基本思想为:在分配资源之前,判断系统是否是安全的;若安全,才分配。它是最具代表性的死锁算法,具体算法如下表示:假设进程P提出请求Requesti,则银行家算法按如下步骤进行判断:1) 如果Requesti <=Needi,则转向2);否则出错。2) 如果Requesti <=Availablei,则转向3);否则出错。3) 系统试探分配相关资源,修改相关数据:Availablei=Availablei-Requesti;Allocationi=Allocationi+Requesti;Needi=Needi-Requesti;4) 系统执行安全性检查,如安全,则分配成立;否则试探性分配资源作废,系统恢复原状,进程进入等待状态。根据以上银行家算法步骤,可得出如下图所示流程图:2.安全性检查算法安全性检查算法主要是根据银行家算法进行资源分配后,检查资源分配后的系统状态是否处于安全状态之中。具体算法如下所示:1) 设置两个工作向量Work=Available,Finish=false;2) 从进程集合中找到一个满足下述条件的进程;Finish=false;Need<=work;如果能够找到该进程,则执行3),否则,执行4);3) 假设上述找到的进程获得资源,可顺利执行,直至完成,从而释放资源。Work=Work+Allocation;Finish=true;Goto 2);4) 如果所有进程的Finish=true,则表示该系统安全,否则系统不安全,请求被拒。5) 根据以上安全检查算法步骤,可得出如下图所示流程图:主要数据结构#include <iostream.h>/全局变量定义int Available100; /可利用资源数组int Max50100; /最大需求矩阵int Allocation50100; /分配矩阵int Need50100; /需求矩阵int Request50100; /M个进程还需要N类资源的资源量int Finish50;int p50;int m,n; /M个进程,N类资源主要代码结构/安全性算法int Safe() int i,j,l=0;int Work100; /可利用资源数组for (i=0;i<n;i+)Worki=Availablei;for (i=0;i<m;i+)Finishi=0;for (i=0;i<m;i+)if (Finishi=1)continue;elsefor (j=0;j<n;j+)if (Needij>Workj)break;if (j=n)Finishi=1;for(int k=0;k<n;k+)Workk+=Allocationik;pl+=i;i=-1;else continue;if (l=m)cout<<"系统是安全的"<<'n'cout<<"系统安全序列是:n"for (i=0;i<l;i+)cout<<pi;if (i!=l-1)cout<<"->"cout<<'n'return 1;/银行家算法int main()int i,j,mi;cout<<"输入进程的数目:n"cin>>m;cout<<"输入资源的种类:n"cin>>n;cout<<"输入每个进程最多所需的各类资源数,按照"<<m<<"x"<<n<<"矩阵输入n"for (i=0;i<m;i+)for(j=0;j<n;j+)cin>>Maxij;cout<<"输入每个进程已经分配的各类资源数,按照"<<m<<"x"<<n<<"矩阵输入n"for (i=0;i<m;i+)for(j=0;j<n;j+)cin>>Allocationij;Needij=Maxij-Allocationij;if (Needij<0)cout<<"你输入的第"<<i+1<<"个进程所拥有的第"<<j+1<<"个资源错误,请重新输入:n"j-;continue;cout<<"请输入各个资源现有的数目:n"for (i=0;i<n;i+)cin>>Availablei;Safe();while (1)cout<<"输入要申请的资源的进程号:(第一个进程号为0,第二个进程号为1,依此类推)n"cin>>mi;cout<<"输入进程所请求的各个资源的数量n"for (i=0;i<n;i+)if (Requestmii>Needmii)cout<<"所请求资源数超过进程的需求量!n"return 0;if (Requestmii>Availablei)cout<<"所请求资源数超过系统所有的资源数!n"return 0;for (i=0;i<n;i+)Availablei-=Requestmii;Allocationmii+=Requestmii;Needmii-=Requestmii;if (Safe()cout<<"同意分配请求n"elsecout<<"SORRY()你的请求被拒绝n"for (i=0;i<n;i+)Availablei+=Requestmii;Allocationmii-=Requestmii;Needmii+=Requestmii;for (i=0;i<m;i+) Finishi=0;char Flag; /标志位cout<<"是否再次请求分配?是请按Y/y,否请按N/n"while (1)cin>>Flag;if (Flag='Y'|Flag='y'|Flag='N'|Flag='n')break;elsecout<<"请按要求重新输入:n"continue;if (Flag='Y'|Flag='y')continue;else break;主要代码段分析1. 在开始编写程序时,由于相关参数由用户自己进行输入时,由于运用scanf和printf语句,造成程序长度很长,而且输入子程序复杂度为O(),程序反应速度也比较慢。后来改用cin和cout函数程序长度大大缩短。2. 由于程序的可重复使用的方便性,采取设立标志位Flag,由用户输入命令(Y/N或y/n)用以作为程序继续运行和结束的标志。实验心得本次试验老师要求对固定的资源进行分配,虽然实现起来比较简单,但是其只能算固定的一种情况,所以在此基础上,我进行了改进,即相关参数由用户自己进行输入增加其实用性。下图为程序运行情况:-第 7 页-

    注意事项

    本文(操作系统银行家算法(7页).doc)为本站会员(1595****071)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开