




已阅读5页,还剩4页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
操作系统实验 死锁的检测与解除 实验报告1、 实验题目:死锁的检测与解除2、 实验内容:编程实现死锁检测与解除,要求能够输入资源数和作业数,输出进程的安全状况。若进程安全,输出安全序列。若进程不安全,发生死锁,可以进行解锁。若成功解锁,输出安全序列。3、 实验目的:通过实验,进一步了解死锁的检测,以及如何解除死锁。4、 实验过程:1、基本思想:若发生死锁,从第一个未完成的进程开始强制释放其已分配资源,然后再次运行安全算法判定系统是否安全。若安全,输出安全序列;若不安全,进入下一个未完成的进程,重复刚刚的步骤。2、主要数据结构:int Max100100=0; /各进程所需各类资源的最大需求;int Available100=0; /系统可用资源;char Name100=0; /资源的名称;int Allocation100100=0; /系统已分配资源;int Need100100=0; /还需要资源int Request100=0; /请求资源向量;int Temp100=0; /存放安全序列;int Work100=0; /存放系统可提供资源;bool Finish100=0;/存放已完成的序列3、输入、输出:输入可用资源种类:3;名称和数量分别为:资源A ,2;资源B,0;资源C,3.进程数:2;最大需求矩阵为:5 5 5 已分配矩阵为:1 1 1 6 6 6 3 5 2得到结果是:进程0 、进程1会发生死锁。进入解锁算法,输出解锁成功,安全序列是01;输入资源种类数4、程序流程图: 输入资源名称输入资源数量输入进程数输入最大需求矩阵输入已分配矩阵判断已分配是否大于最大需求大于最大需求 小于最大需求 进行预分配进行预分配开始解锁安全性算法 未通过 通过 安全性算法 失败成功分配并输出安全系列 解锁成功5、 实验结果截屏:6、 源程序代码:#include#define False 0#define True 1using namespace std;int Max100100=0; /各进程所需各类资源的最大需求;int Available100=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系统可用资源Available: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(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;elsefor(j=0;jWorkj)break;if(j=N)/若Need都小于Work Finishi=true;for(k=0;kN;k+)Workk+=Allocationik; /进程i执行完后回收资源Templ+=i;i=-1;elsecontinue; if(l=M)cout系统是安全的endl;cout安全序列:endl;for(i=0;il;i+)coutTempi;if(i!=l-1)cout;coutendl;return true; /cout会发生死锁,发生死锁的进程是:endl;for(i=0;iM;i+)if(Finishi=false)cout会发生死锁,发生死锁的进程是:i endl;coutendl;return false;int main()int i,j,number,m,n,flag;int over;char mc;coutn;N=n;for (i=0;in;i+)cout资源i+1mc;Namei=mc;coutnumber;Availablei=number;/end forcoutendl;coutm;M=m;cout请输入各进程的最大需求量(m*n矩阵)Max:endl;for ( i=0;im;i+)for ( j=0;jMaxij;doflag=0;cout请输入各进程已经分配资源量(m*n矩阵)Allocation:endl;for (int i=0;im;i+)for (j=0;jAllocationij;if(AllocationijMaxij)flag=1;Needij=Maxij-Allocationij;if(flag)cout首次输入的已分配资源已经大于最大需求量,请重新输入!n;while(flag);/ 当申请资源符合要求时,flag恒, end do ShowData();/显示Safe();/安全
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 初中英语工作坊管理制度
- 东风公司ilu管理制度
- 景区应急安全管理制度
- 劳务工人进出厂管理制度
- 创新公司项目组管理制度
- 地铁人性化设备管理制度
- 景区休息候场管理制度
- 月子中心前厅管理制度
- 外墙外保温公司管理制度
- 化工类公司安全管理制度
- 事故隐患通报制度(5篇)
- Unit3Reading课件-高中英语牛津译林版(2020)必修第三册
- 5-1贯入法砌筑砂浆砂浆抗压强度检测方案
- 锚杆加固施工方案(通用版)
- 地源热泵埋管冬夏季换热平衡计算
- 甲骨文专‖教学课件
- 规章制度和操作规程的管理制度范本
- 形式发票格式2 INVOICE
- 清华大学美术学院陶瓷艺术设计系研究生导师及研究课题
- 理论力学运动学题库
- 计算机控制实验报告初稿(共31页)
评论
0/150
提交评论