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

开通VIP
 

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

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请。


权利声明

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

注意事项

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

操作系统课程设计模拟银行家算法避免死锁.doc

1、 操作系统课程设计模拟银行家算法避免死锁 22 2020年4月19日 文档仅供参考,不当之处,请联系改正。 模拟经过银行家算法避免死锁 一、 银行家算法产生的背景及目的 1:在多道程序系统中,虽然借助于多个进程的并发执行来改进系统的利用率,提高系统的吞吐量,但可能发生一种危险—死锁。死锁就是多个进程在运行过程中因争夺资源而造成的一种僵局,当进程处于这种僵局状态时,如无外力作用,她们将无法再向前进行,如再把信号量作为同步工具时,多个Wait和Signal操作顺序不当,会产生进程死锁。 然而产生死锁的必要条件有互斥条件,请求和保持

2、条件,不剥夺条件和环路等待条件。在预防死锁的几种方法中,都施加了较强的限制条件,在避免死锁的方法中,所施加的条件较弱,有可能获得令人满意的系统性能。在该方法中把系统的状态分为安全状态和不安全状态,只要能使系统都处于安全状态,便可避免死锁。 2:实验目的:让学生独立的使用编程语言编写和调试一个系统分配资源的简单模拟程序,了解死锁产生的原因及条件。采用银行家算法及时避免死锁的产生,进一步理解课堂上老师讲的相关知识点。银行家算法是从当前状态出发,逐个按安全序列检查各客户中谁能完成其工作,然后假定其完成工作且归还全部贷款,再进而检查下一个能完成工作的客户。如果所有客户都能完成工作,则找到一个安全序列

3、银行家才是安全的。 二:银行家算法中的数据结构 1:可利用资源向量Available。这是一个含有m个元素的数组,其中的每个元素代表一类可利用的资源数目,其初始值是系统中所配置的该类全部可用资源的数目,其数值随该类资源的分配和回收而动态的改变。如果Available[j]=k,z 则表示系统中现有Rj类资源K 个。 2:最大需求矩阵Max。这是一个n*m的矩阵,它定义了系统中n个进程中的每一个进程对m类资源的最大需求。如果Max[i,j]=k,表示第i个进程需要第Rj类资源的最大数目k个. 3: 分配矩阵Allocation,也是n*m的矩阵,若Allocation[i,j]

4、k,表示第i 个进程已分配Rj类资源的数目为k个。 4:需求矩阵Need。也是一个n*m的矩阵,Need[i,j]=k,表示第i个进程还需Rj类资源k个。 三、银行家算法及安全性算法 1:银行家算法 设Request[i]是进程Pi的请求向量,若Request[i][j]=k;表示进程需要j类资源k个。当Pi发出资源请求时,系统按下属步骤进行检查; (1) 如果Request[i][j]<=Need[i][j];便转向步骤(2),否则认为出错,因为它所需要的资源数已超过她所宣布的最大值。 (2) 如果Request[i][j]<=Available[i][j],便转向步骤

5、3),否则认为尚无足够资源,进程需等待。 (3) 系统试探着把资源分配给进程,并修改下面数据结构的数据 Available[i][j]=Available[i][j]-Request[i][j]; Allocation[i][j]=Allocation[i][j]+Request[i][j]; Need[i][j]=Need[i][j]-Request[i][j]; (4) 系统执行安全性算法,检查此次资源分配后系统是否处于安全状态。若安全,才正式将资源分配给进程Pi,已完成此次分配。否则,将本次的试探分配作废,回复原来的资源分配状态,将进程Pi等待。 2:安全性算法 (1)

6、设置两个向量; 1:工作向量Work,表示系统可提供给进程运行所需的各类资源数目,它含有m个元素,初始时Work=Available 2:Finish ,表示系统是否有足够的资源分配给进程,使之运行完成。开始时先做Finish[i]=true (2) 从进程中找到一个能满需下属条件的进程 1;Finish[i]=false; 2:Need[i][j]<=Work[j];若找到执行步骤(3),否则执行步骤(4) (3) 当进程Pi顺利获得资源后,直至完成,并释放分配给它的资源,执行: Work[j]=Work[j]+Allocation[i][j]; Fini

7、sh[i]=true; Go to step (2); (5) 如果所有的进程Finish[i]都满足,则表示系统处于安全状态,否则,处于不安全状态。 四、模块设计与分析及整体功能概述 模块设计与分析: 整个银行家算法分为初始化函数Init(),安全性算法函数 safe(),银行家算法函数bank()三部分。初始化函数生成开始时刻系统中的进程和资源情况,安全性算法判断当某进程申请资源时,系统能否处于安全状态。在本实验中,若系统处于安全状态,便生成一个安全进程序列(安全序列可能有多个)。银行家算法函数bank()负责整体的检查与异常判断。 整体功能概述: 死锁会引起系

8、统陷入僵局,操作系统必须防止此现象的发生。本实验经过一个动态分配资源的模拟程序,更清楚的理解死锁产生的原因和条件。Dijkstra的银行家算法是最有代表性的避免死锁的方法。运行程序时用户设定系统中进程和可利用资源的种类数目。输入各进程的可利用资源Available,最大需求MAX,已分配资源Allocation ,需求资源Need,之后各系统发出资源请求Request,利用实验中的安全性算法判断能否产生一个安全性队列,若能,则给该进程分配成功,否则,不予分配。 五、流程图设计 六、源代码及调试分析 #include #define MAXm 5

9、0 // 定义最大进程数 #define MAXn 100 //定义最大资源数 int MAX[MAXm][MAXn]; //最大需求矩阵 int Allocation[MAXm][MAXn]; //已分配矩阵 int Available[MAXn]; //可用资源数组 int Need[MAXm][MAXn]; //需求矩阵 int Request[MAXm][MAXn]; //请求矩阵 int Finish[MAXm];

10、 //存储完成资源分配的进程 int Sequence[MAXm]; //模拟的资源分配序列 int Work[MAXn]; //系统是否有足够的资源分配给进程 int m,n; //m个进程,n个资源 #define False 0 #define True 1 void input(); //数据输入函数 int safealg(); //安全性算法函数 void banker(); //银行家算法函数 void main() {input();safealg();banker

11、);} //*************初始化算法*************** void input() { int i,j; //************自定义进程数目与资源种类******************* cout<<"***********************************\n"; cout<<"*利用银行家算法避免死锁*\n"; cout<<"* *\n"; cout<<"************************************\n"; cout<<

12、"请输入进程的数目:"; cin>>m; cout<<"请输入资源的种类:"; cin>>n; //*****输入每个进程对每种资源的最大需求、已经获得的数量、每种类型资源的数目 cout<<"各进程资源最大需求(Max),按照"<>MAX[i][j]; if(j==n) cout<<"资源种类数匹配出现错误!";//当资源配置的种类数大于预先输入的数值时

13、出错 } } cout<<"各进程当前获得资源(Allocation),按照"<>Allocation[i][j]; if(j==n) cout<<"资源种类数匹配出现错误!";//当资源配置的种类数大于预先输入的数值时,出错 Need[i][j]=MAX[i][j]-Allocation[i][j];//需求数等于最大需求减去已经分配数

14、 } } cout<<"系统可用资源(Available):"<>Available[j];//输入各种资源的可利用数 } cout<<"当前时刻的进程分配情况如图:\n"; cout<<"进程号-"<<"MAX----"<<"Allocation---"<<"Need--"<<"Available---\n";//显示各进程的资源情况 for(i=0;i

15、t<<" "<

16、j; int choice; while(1) { cout<>choice; if(choice==1) //分配资源 { cout<<"从P0到P"<>i; if(i>=m) { cout<<"无此进程号!请重新输入:\n";

17、 cin>>i;//重新输入进程号 } cout<<"请输入进程申请的资源(Request):"<>Request[i][j]; //**********银行家算法进行检查*************// for(j=0;jNeed[i][j]) { cout<<"申请的资源大于它需要的资源数,请重新输入!\n";//资源申请不合理 continue;

18、 } if(Request[i][j]>Available[j]) { //资源申请数目大于可利用数,无法分配,得等待 cout<<"当前系统可用资源不够,请等待!"<

19、est[i][j];//所得资源增加 Need[i][j]=Need[i][j]-Request[i][j]; //仍需资源减少 } if(safealg()<0)//安全性算法的返回值 { cout<<"分配不成功,请等待!"; for (j=0;j

20、 Need[i][j]=Need[i][j]+Request[i][j]; } for(i=0;i

21、<<"Need---"<<"Allocation---"<<"Work+Allocation--" <<"Finish--"<

22、 cout<<" "; for(j=0;j

23、cation[Sequence[i]][j]+Work[j];//回收该进程所分配的资源 cout<=0) }//if(choice=1) else if(choice==2) //离开———— break; else cout<<"请输入1或2!";//只认可1或2 }//while(1) } //*********安全性算法 ************// int safealg() { int i,j,k,l=0; //int Work[MAX

24、n]; //工作组 //记录序列 for(i=0;i

25、 //对于未运行的进程,进行如下处理 {/// for(j=0;jWork[j])//由于部分资源得不到满足,进程i无法运行 { break; } } if(j==n)//进程各类资源全部得到满足 { Finish[i]=True; for(k=0;k

26、 Work[k]+=Allocation[i][k]; //工作分配加上可用资源 } Sequence[l++]=i; //模拟资源分配序列生成 i=-1; //重新扫描所有进程从i=0开始 } else { //某一资源得不到满足 continue; //试探下一个进程 } }// if(l==m)//都试探完毕 { cout<<"系统安全!"<

27、 cout<<"进程P"< "; cout<

28、始。 七、运行结果 假设输入进程个数为5,资源种类数为3,并以此输入各进程初始时刻的各种资源数量 ,如下 若再继续申请资源,假设为P4 ,申请资源(1 2 2) 假设P1 申请资源(2 2 4)有 八、心得体会 经过这次操作系统课程设计,让我受益匪浅,收获颇多。主要体会如下: 1.利用Vc++编译程序编写银行家算法,进一步理解到经过银行家算法避免死锁的思想,同时也理解了系统死锁产生的原因及条件。 2.在实验过程中所有的设计步骤遵循老师教授的程序功能化的思想,分别定义了三个函数,init()初始化函数,safealg()安全性算法函数,bank()银行家算法函数,体现了函数的模块化思想。这样的话,不但提高了程序的可读性和可操作性,而且还提高了CPU的利用率和内存的利用率,因为程序的运行是局部性的,这种思想对于段页式存储管理系统尤为重要。 3.实验过程中遇到的种种疑难问题经过自己上网查找答案,锻炼了自己纠错能力和搜索有价值信息的能力及自学的能力,而且进一步巩固了自己以前学过的专业知识。

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

关于我们      便捷服务       自信AI       AI导航        抽奖活动

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

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

gongan.png浙公网安备33021202000488号   

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

关注我们 :微信公众号    抖音    微博    LOFTER 

客服