ImageVerifierCode 换一换
格式:DOCX , 页数:11 ,大小:184.44KB ,
资源ID:27794612      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

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

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

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(实验三死锁的检测和解除之欧阳德创编.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

实验三死锁的检测和解除之欧阳德创编.docx

1、实验三死锁的检测和解除之欧阳德创编南华大学计算机科学与技术学院时间:2021.03.07创作:欧阳德实验报告课程名称 操作系统I姓 名学 号专业班级任课教师日 期一、实验内容死锁的检测与解除二、实验目的掌握操作系统的进程管理与资源分配原理,掌握对操作系统安全性检验和死锁的解除的原理和方法。三、实验题目系统中有 m 个同类资源被 n 个进程共享,每个进程对资源的最大需求数分别为 S1,S2,Sn,且 Max(Si)=m, (i=1,2,n)。进程可以动态地申请资源和释放资源。编写一个程序,实现银行家算法,当系统将资源分配给某一进程而不会死锁时,就分配之。否则,推迟分配,并显示适当的信息。分别使用

2、检测“进程资源循环等待链”的方法和 Coffman 的算法来检测进程的死锁状态。对于相同的进程资源分配、占用次序,比较两个算法的结果。四、设计思路和流程图1.输入系统进程数量n和资源类型数量m。 2.输入每类资源的数量。 3.输入每个进程每类资源的最大需求量和已获资源量。 4.检验系统的安全。 5.若检测结果为系统不安全,可以对死锁进行解除,直到安全为止再检测。 6.重复5操作,直到所有进程运行完毕。五、主要数据结构及其说明int Max100100=0; /各进程所需各类资源的最大需求; int Available100=0; /系统可用资源; char Name100=0; /资源的名称;

3、 int Allocation100100=0; /系统已分配资源; int Need100100=0; /还需要资源 int Request100=0; /请求资源向量; int Temp100=0; /存放安全序列; int Work100=0; /存放系统可提供资源; bool Finish100=0;/存放已完成的序列六、源程序并附上注释#include stdafx.h #include #define False 0 #define True 1 using namespace std; int Max100100=0; /各进程所需各类资源的最大需求; int Available

4、100=0; /系统可用资源; char Name100=0; /资源的名称; int Allocation100100=0; /系统已分配资源; int Need100100=0; /还需要资源 int Request100=0; /请求资源向量; int Temp100=0; /存放安全序列; int Work100=0; /存放系统可提供资源; bool Finish100=0; int M=100; /作业的最大数 int N=100; /资源的最大数 int l=0;/记录安全进程的TEMP下标 void ShowData()/初始化资源矩阵 int i,j; cout系统可用资源A

5、vailable:endl; for(i=0;iN;i+) coutNamei ; coutendl; for(j=0;jN;j+) coutAvailablej ;/显示可分配的资源 coutendl; cout Max Allocation Needendl; cout进程名 ; for (j=0;j3;j+)/MAX ALLOCATION NEED 共列 for (i=0;iN;i+) coutNamei ; cout ; coutendl; for(i=0;iM;i+) cout i ;/输出进程名 for(j=0;jN;j+) coutMaxij ;/输出最大 cout ; for(

6、j=0;jN;j+) coutAllocationij ;/输出已分配 cout ; for(j=0;jN;j+) coutNeedij ;/输出需求 coutendl; bool Safe() /安全性算法 int i,j,k; for(i=0;iN;i+) Worki=Availablei; /初始化工作向量 for(i=0;iM;i+) Finishi=false; /判断进程i是否已执行 for(i=0;iM;i+) if(Finishi=true) continue; else for(j=0;jWorkj) break; if(j=N)/若Need都小于Work Finishi=t

7、rue; for(k=0;kN;k+) Workk+=Allocationik; /进程i执行完后回收资源 Templ+=i; i=-1; else continue; if(l=M) cout系统是安全的endl; cout安全序 列:endl; for(i=0;il;i+) coutTempi; if(i!=l-1) cout; coutendl; return true; for(i=0;iM;i+) if(Finishi=false) cout会发生死锁,发生死锁的进程是:i endl; coutendl; return false; void unlock() int i,j; i=

8、0; cout死锁解除开始; coutendl; while(iM&Finishi=false) /查找未完成的进程 for(j=0;jN;j+) Availablej+=Allocationij; /回收该进程所有资源 Allocationij=0; if(Safe() cout死锁已解除endl; else i+;/到下一个进程 Safe(); int main() int i,j,number,m,n,flag; int over; char mc; cout-死锁的检测与解除-; coutendl; coutendl; coutn; N=n; for (i=0;in;i+) cout资

9、源i+1mc; Namei=mc; cout资源i+1number; Availablei=number; coutendl; coutendl; coutm; M=m; cout请输入各进程的最大需求量(m*n矩阵)Max:endl; for (int i=0;im;i+) for (int j=0;jMaxij; do flag=0; cout请输入各进程已经分配资源量(m*n矩阵)Allocation:endl; for (int i=0;im;i+) for (j=0;jAllocationij; if(AllocationijMaxij) flag=1; Needij=Maxij-A

10、llocationij; if(flag) cout首次输入的已分配资源已经大于最大需求量请重新输入!n; while(flag);/ 当申请资源符合要求时 end do ShowData();/显示 Safe();/安全检测 if(l!=m)/当安全进程数不等于所有进程数 unlock(); cout运行结束over; 七、程序运行时的初值和运行结果八、实验体会通过本次实验,比较完整的掌握了操作系统的进程管理与资源分配原理,以及对操作系统安全性检验和死锁的解除的原理和方法。一开始,对于死锁的解除,我只是从第一个进程开始剥夺其资源,也不管它是不是发生了死锁,一直剥夺到死锁解除为止。然后,通过对程序进行改进,让其可以判断死锁进程与非死锁进程,然后从第一个死锁进程开始剥夺已分配资源。到最后,又进一步完善程序,让其判断一下在死锁进程中,哪个的已分配资源最多,就先剥夺它的资源,直到死锁解除。通过以上这几次对程序的改进,我不仅对死锁的解除有了更进一步的理解,也加深了对编程理念的认识。一种好的编程习惯、编程理念不仅可以帮助减少工作量,更可以帮助编程人员对程序的思想进行全面理解,对程序需求进行全面理解。时间:2021.03.07创作:欧阳德

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1