設备管理实验报告.docVIP

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
設备管理实验报告

数学学院实验报告 课程名称: 操作系统 实验项目名称: 设备管理 实验时间:2014年5月21日 班级:计算111 姓名: 陈建峰 学号:110402104 实 验 目 的: 1.对理论课中学习的设备管理中的概念作进一步的理解;2.明白设备管理的主要任务;3.了解设备管理任务的主要实现方法;4.通过编程,学会独占设备的分配、回收等主要算法的原理 PC机、windows2000 操作系统、Turbo C 2.0 / VC++6.0 实 验 内 容 及 过 程: 此实验通过模拟方法来实现简单的独占设备的分配和回收。 在操作系统中,通过设置“设备分配表”来记录计算机系统所配置的独占设备的类型、数量及分配情况。为了实现设备分配、回收过程的独立性,设备分配表一般由“设备类表”和“设备表”两部分组成。 “设备类表”记录了系统中的各类设备,每类设备占用一个登记项,登记该类设备的总数量、当前有几台空闲设备以及该类设备在设备表中的起始地址。 设备类表结构 设备类 设备数量 当前空闲设备数量 在设备表起始地址 Printer 3 2 16 …… …… …… …… 设备表中登记每一台设备的绝对号、设备使用情况的好坏、设备是否分配、设备被哪一个作业占用及设备相对号。每一台设备在“设备表”占用一个登记项,同类的若干台设备连续登记在设备表中。 设备表结构 绝对号 好/坏 已/未分配 占用作业名 相对号 116 1 1 J1 2 …… …… …… …… …… 1. 独占设备分配 设备申请某台设备时,系统先查“设备类表”,如果该类设备的现存可使用数量可以满足申请要求,则从“设备类表”中得到该类设备的设备表起始地址,然后找到“设备表”中该类设备的起始地址,依次查询该类设备的每个登记项,找出“好的且未分配”的设备分配给该作业。分配后要修改设备类表中的现存设备数量(减1);修改设备表中设备状态为“已分配”,并填上占用该设备的作业的作业名和程序中定义的相对号,最后将设备的绝对号与相对号的对应关系通知用户。 设备分配参考代码: 2. 独占设备回收 作业运行完成,释放设备时,根据该设备的类型查找设备类表,根据其中的地址,找到该类设备在设备表中的地址,找到作业名相同且已分配的表项,将其已分配改为未分配,然后将设备表中对应设备类的可使用数量增加1。 实 验 结 果 及 分 析: 1.程序初始界面: 2.设备分配,依次输入: w input 3 4.回收设备:w input 实 验 心 得:通过这次试验我对理论课中学习的设备管理中的概念作进一步的理解明白设备管理的主要任务通过编程,学会独占设备的分配、回收等主要算法的原理#includestdio.h #includestring.h #includestdlib.h #includemath.h #define false 0 #define true 1 #define n 4 #define m 10 struct { char type[10]; /*设备类名*/ int count; /*拥有设备台数*/ int remain; /*现存的可用设备台数*/ int address; /*该类设备在设备表中的起始地址*/ }equiptype[n]; /*设备类表定义,假定系统有n个设备类型*/ struct { int number; /*设备绝对号*/ int status; /*设备好坏状态*/ int remain; /*设备是否已分配*/ char jobname[4];/*占有设备的作业名*/ int lnumber; /*设备相对号*/ }equipment[m]; /*设备表定义,假定系统有m个设备*/ allocate(char *J,char *type,int cc) { int i,t,j; /*查询该类设备*/ i=0; while(instrcmp(equiptype[i].type,type)!=0) i++; if(i=n)/*没有找到该类设备*/ { printf(无该类设备,设备分配失败); return(false); } if(equiptype[i].remain1)/*所需设备现存可用台数不足*/ { printf(该类设备不足,分配失败); return(false); } t=equiptype[i].address

文档评论(0)

df9v4fzI + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档