还剩14页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
操作系统课程报告实验六设备管理学号姓名班级教师华侨大学电子工程系实验目的
1、理解设备管理的概念和任务
2、掌握独占设备的分配、回收等主要算法的原理并编程实现实验内容与基本要求
1、在Windows系统中,编写程序实现对独占设备的分配和回收的模拟,该程序中包括建立设备类表和设备表、分配设备和回收设备的函数实验报告内容
1、独占设备的分配、回收等主要算法的原理为了提高操作系统的可适应性和可扩展性,现代操作系统中都毫无例外地实现了设备__性,又叫做设备无关性设备__性的含义是应用程序__于具体使用的物理设备为了实现独占设备的分配,系统设置数据表格的方式也不相同,在实验中只要设计合理即可这里仅仅是一种方案,采用设备类表和设备表
(1)数据结构操作系统设置“设备分配表”,用来记录计算机系统所配置的独占设备类型、台数以及分配情况设备分配表可由“设备类表”和“设备表”两部分组成,如下图
(2)设备分配当进程申请某类设备时,系统先查“设备类表”如果该类设备的现存台数可以满足申请要求,则从该类设备的“设备表”始址开始依次查该类设备在设备表中的登记项,找出“未分配”的设备分配给进程分配后要修改设备类表中的现存台数,把分配给进程的设备标志改为“已分配”且填上占用设备的进程名然后,把设备的绝对号与相对号的对应关系通知用户,以便用户在分配到的设备上装上存储介质
(3)设备回收当进程执行结束撤离时应归还所占设备,系统根据进程名查设备表,找出进程占用设备的登记栏,把标志修改为“未分配”,清除进程名同时把回收的设备台数加到设备类表中的现存台数中
2、程序流程图主程序流程图设备分配设备回收
3、程序及注释#includestdio.h#includestring.h#includestdlib.h#definefalse0#definetrue1#definen4/*宏定义,用于修改设备类型数目*/#definem10/*宏定义,用于修改设备数目*/struct/*该结构体用于定义设备类表各信息*/{chartype
[10];/*设备类型名*/intcount;/*拥有的设备总台数*/intre__in;/*现存的可用设备台数*/intaddress;/*该类设备在设备表中的起始地址*/}equiptype[n];/*系统设备类型为n*/struct/*该结构体用于定义设备表各信息*/{intnumber;/*设备绝对编号*/intlnumber;/*设备相对编号*/intstatus;/*设备好坏状态*/intre__in;/*设备是否已被分配*/charjobname
[4];/*占有设备的作业名*/}equipment[m];/*系统设备数为m*//**********************子函数作业设备分配*****************************/allocatechar*Jchar*typeintcc{intitj;i=0;whileinstrcmpequiptype[i].typetype!=0/*查找欲申请分配的设备类型,strcmp函数用于比较equiptype[i].type与type的大小,若相等则返回0*/i++;ifi=n/*若没有找到欲申请设备*/{printf没有找到欲分配的设备分配失败!;returnfalse;}ifequiptype[i].re__in1/*欲申请设备现存可用台数不足*/{printf该类设备数量不足,分配失败!;returnfalse;}t=equiptype[i].address;/*取出该类设备在设备表中的起始地址赋给t*/while!equipment[t].status==1equipment[t].re__in==0t++;/*该设备类型起始地址加一*/equiptype[i].re__in--;/*剩余设备数减一*/equipment[t].re__in=1;/*状态改为已分配*/strcpyequipment[t].jobnameJ;/*strcpy为字符串拷贝函数,把J中的字符串拷贝到equipment[t].jobname中*/equipment[t].lnumber=cc;/*设备相对号写入cc*/}/**********************子函数作业设备回收*****************************/reclaimchar*Jchar*type{intitjknn;i=0;whileinstrcmpequiptype[i].typetype!=0/*查找欲申请归还的设备类型,strcmp函数用于比较equiptype[i].type与type的大小,若相等则返回0*/i++;ifi=n/*若没有找到该类设备*/{printf无该类设备设备回收失败!;returnfalse;}t=equiptype[i].address;/*取出该类设备在设备表中的起始地址赋给t*/j=equiptype[i].count;/*取出该类设备的数量赋给j*/k=0;nn=t+j;for;tnn;t++ifstrcmpequipment[t].jobnameJ==0equipment[t].re__in==1/*若占用某个设备的作业与欲回收的作业相同且状态为已分配*/{equipment[t].re__in=0;/*则将其状态改为未分配*/k++;/*回收设备计数*/}equiptype[i].re__in=equiptype[i].re__in+k;/*该类设备剩余设备数加k*/ifk==0/*若回收设备计数值k为0*/printf本作业没有占用这类资源!/n;}/**********************主函数*****************************/void__in{charJ
[4];intimma;chartype
[10];printf设备类初始化\n;fori=0;i4;i++/*输入设备类表初始信息*/{printf请输入相应设备名称;scanf%sequiptype[i].type;printf请输入相应设备的数量;scanf%dequiptype[i].count;printf请输入当前空闲设备数量;scanf%dequiptype[i].re__in;printf请输入设备表起始地址;scanf%dequiptype[i].address;}fori=0;i10;i++/*初始化设备表*/{equipment[i].number=i;equipment[i].status=1;equipment[i].re__in=0;}while1{printf\n0-退出1-分配2-回收3-显示;/*功能选择界面*/printf\n请选择功能0-3:;scanf%da;switcha{case0:/*a=0程序结束*/exit0;case1:/*a=1分配设备*/printf请输入作业名、作业所需设备类型和设备相对号\n;scanf%s%s%dJtypemm;allocateJtypemm;/*分配设备*/break;case2:/*a=2回收设备*/printf请输入作业名和作业归还的设备类\n;scanf%s%sJtype;/*输入要回收的作业名及对应的设备类*/reclaimJtype;/*回收设备*/break;case3:/*a=3输出设备类表和设备表的内容*/printf输出设备类表!\n;/*输出设备类表内容*/printf设备类型设备总量空闲好设备起始地址\n;fori=0;in;i++printf%9s%16d%22d%14d\nequiptype[i].typeequiptype[i].countequiptype[i].re__inequiptype[i].address;printf输出设备表:\n;/*输出设备表内容*/printf绝对号好/坏已/未分配占用作业名相对号\n;fori=0;im;i++printf%3d%11d%15d%15s%9d\nequipment[i].numberequipment[i].statusequipment[i].re__inequipment[i].jobnameequipment[i].lnumber;}}}
4、运行结果以及结论初始化输入设备分配设备回收可见在设备b回收j1后,设备b的‘已/未分配’变为了
0.。