- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验二独占设备分配与回收
实验二 独占设备分配与回收
实验目的:
加深对设备管理的理解。
深入了解如何分配和回收独占设备。
实验预备知识:
设备独立性。
独占设备的特性。
系统设备表和物理设备表。
实验内容:
设计一种独占设备分配和回收的方案,要求满足设备独立性。编写程序实现这个方案并进行测试。
提示与讲解:
为了提高操作系统的可适应性和可扩展性,现代操作系统中都毫无例外地实现了设备独立性,又叫做设备无关性。设备独立性的含义是:应用程序独立于具体使用的物理设备。
为了实现独占设备的分配,系统设置数据表格的方式也不相同,在实验中只要设计合理即可。这里仅仅是一种方案,采用设备类表和设备表。
数据结构
操作系统设置“设备分配表”,用来记录计算机系统所配置的独占设备类型、台数以及分配情况。设备分配表可由“设备类表”和“设备表”两部分组成,如下图:
设备类 总台数 空闲台数 设备表始址 输入机 2 1 打印机 1 1 …… 设备物理名 是否分配 占用进程 001 未分配 002 已分配 J1 …… 003 未分配 …… …… …… …… 设备类表
设备表
设备分配
当进程申请某类设备时,系统先查“设备类表”。
如果该类设备的现存台数可以满足申请要求,则从该类设备的“设备表”始址开始依次查该类设备在设备表中的登记项,找出“未分配”的设备分配给进程。
分配后要修改设备类表中的现存台数,把分配给进程的设备标志改为“已分配”且填上占用设备的进程名。
然后,把设备的绝对号与相对号的对应关系通知用户,以便用户在分配到的设备上装上存储介质。
设备回收
当进程执行结束撤离时应归还所占设备,系统根据进程名查设备表,找出进程占用设备的登记栏,把标志修改为“未分配”,清除进程名。同时把回收的设备台数加到设备类表中的现存台数中。
参考程序:
#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(J,type,mm)
char *J,*type;
int mm;
{int i,t,j;
i=0;
while(instrcmp(equiptype[i].type,type)!=0)
i++;
if(i=n)
{cout”无该类设备,设备分配失败”endl;
return False;
}
if(equiptype[i].remain1)
{ cout”该类设备不足,分配失败”endl;
return False;
}
t=equiptype[i].address;
while(!(equipment[t].remain==0))
t++;
equiptype[i].remain--;
equipment[t].remain=1;
strcpy(equipment[t].jobname,J);
equipment[t].lnumber=mm;
return 1;
}
reclaim(J,type)
char J,type;
{int i,t,j,k,nn;
i=0;
while(instrcmp(equiptype[i].type,type)!=0)
i++;
if(i=n)
{cout”无该类设备,设备分配失败”endl;
return False;
}
t=equiptype[i].address;
j=equiptype[i].count;
k=0;
nn=t+j;
for(;tnn;t++)
if(strcmp(equipment[t].jobname,J)==0equipment[t].remain==1)
{
equipment[t].remain=0;
k++;
}
equiptype[i].remain=equiptype[i].remain+k;
if(k==0)
cout”该进程没有使用该类设备”endl;
return 1;
}
main()
{char J[4];
i
文档评论(0)