操作系统实验六设备管理Word文件下载.docx

上传人:b****1 文档编号:1280045 上传时间:2023-04-30 格式:DOCX 页数:14 大小:241.58KB
下载 相关 举报
操作系统实验六设备管理Word文件下载.docx_第1页
第1页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第2页
第2页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第3页
第3页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第4页
第4页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第5页
第5页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第6页
第6页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第7页
第7页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第8页
第8页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第9页
第9页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第10页
第10页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第11页
第11页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第12页
第12页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第13页
第13页 / 共14页
操作系统实验六设备管理Word文件下载.docx_第14页
第14页 / 共14页
亲,该文档总共14页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

操作系统实验六设备管理Word文件下载.docx

《操作系统实验六设备管理Word文件下载.docx》由会员分享,可在线阅读,更多相关《操作系统实验六设备管理Word文件下载.docx(14页珍藏版)》请在冰点文库上搜索。

操作系统实验六设备管理Word文件下载.docx

这里仅仅是一种方案,采用设备类表和设备表。

(1)数据结构

操作系统设置“设备分配表”,用来记录计算机系统所配置的独占设备类型、台数以及分配情况。

设备分配表可由“设备类表”和“设备表”两部分组成,如下图:

(2)设备分配

当进程申请某类设备时,系统先查“设备类表”如果该类设备的现存台数可以满足申请要求,则从该类设备的“设备表”始址开始依次查该类设备在设备表中的登记项,找出“未分配”的设备分配给进程。

分配后要修改设备类表中的现存台数,把分配给进程的设备标志改为“已分配”且填上占用设备的进程名。

然后,把设备的绝对号与相对号的对应关系通知用户,以便用户在分配到的设备上装上存储介质。

(3)设备回收

当进程执行结束撤离时应归还所占设备,系统根据进程名查设备表,找出进程占用设备的登记栏,把标志修改为“未分配”,清除进程名。

同时把回收的设备台数加到设备类表中的现存台数中。

2、程序流程图。

主程序流程图:

设备分配:

设备回收:

3、程序及注释。

#include<

stdio.h>

string.h>

stdlib.h>

#definefalse0

#definetrue1

#definen4/*宏定义,用于修改设备类型数目*/

#definem10/*宏定义,用于修改设备数目*/

struct/*该结构体用于定义设备类表各信息*/

{chartype[10];

/*设备类型名*/

intcount;

/*拥有的设备总台数*/

intremain;

/*现存的可用设备台数*/

intaddress;

/*该类设备在设备表中的起始地址*/

}

equiptype[n];

/*系统设备类型为n*/

struct/*该结构体用于定义设备表各信息*/

{

intnumber;

/*设备绝对编号*/

intlnumber;

/*设备相对编号*/

intstatus;

/*设备好坏状态*/

/*设备是否已被分配*/

charjobname[4];

/*占有设备的作业名*/

equipment[m];

/*系统设备数为m*/

/**********************子函数:

作业设备分配*****************************/

allocate(char*J,char*type,intcc)

{

inti,t,j;

i=0;

while(i<

n&

&

strcmp(equiptype[i].type,type)!

=0)/*查找欲申请分配的设备类型,strcmp函数用于比较equiptype[i].type与type的大小,若相等则返回0*/

i++;

if(i>

=n)/*若没有找到欲申请设备*/

{

printf("

没有找到欲分配的设备,分配失败!

"

);

return(false);

}

if(equiptype[i].remain<

1)/*欲申请设备现存可用台数不足*/

printf("

该类设备数量不足,分配失败!

return(false);

}

t=equiptype[i].address;

/*取出该类设备在设备表中的起始地址赋给t*/

while(!

(equipment[t].status==1&

equipment[t].remain==0))

t++;

/*该设备类型起始地址加一*/

equiptype[i].remain--;

/*剩余设备数减一*/

equipment[t].remain=1;

/*状态改为已分配*/

strcpy(equipment[t].jobname,J);

/*strcpy为字符串拷贝函数,把J中的字符串拷贝到equipment[t].jobname中*/

equipment[t].lnumber=cc;

/*设备相对号写入cc*/

}

/**********************子函数:

作业设备回收*****************************/

reclaim(char*J,char*type)

inti,t,j,k,nn;

=0)/*查找欲申请归还的设备类型,strcmp函数用于比较equiptype[i].type与type的大小,若相等则返回0*/

=n)/*若没有找到该类设备*/

printf("

无该类设备,设备回收失败!

return(false);

/*取出该类设备在设备表中的起始地址赋给t*/

j=equiptype[i].count;

/*取出该类设备的数量赋给j*/

k=0;

nn=t+j;

for(;

t<

nn;

t++)

if(strcmp(equipment[t].jobname,J)==0&

equipment[t].remain==1)/*若占用某个设备的作业与欲回收的作业相同且状态为已分配*/

equipment[t].remain=0;

/*则将其状态改为未分配*/

k++;

/*回收设备计数*/

equiptype[i].remain=equiptype[i].remain+k;

/*该类设备剩余设备数加k*/

if(k==0)/*若回收设备计数值k为0,*/

printf("

本作业没有占用这类资源!

/n"

}

/**********************主函数*****************************/

voidmain()

charJ[4];

inti,mm,a;

chartype[10];

设备类初始化\n"

for(i=0;

i<

4;

i++)/*输入设备类表初始信息*/

{

请输入相应设备名称:

scanf("

%s"

&

equiptype[i].type);

请输入相应设备的数量:

%d"

equiptype[i].count);

请输入当前空闲设备数量:

equiptype[i].remain);

请输入设备表起始地址:

equiptype[i].address);

for(i=0;

10;

i++)/*初始化设备表*/

equipment[i].number=i;

equipment[i].status=1;

equipment[i].remain=0;

while

(1)

\n0-退出,1-分配,2-回收,3-显示"

/*功能选择界面*/

\n请选择功能(0-3):

a);

switch(a)

case0:

/*a=0程序结束*/

exit(0);

case1:

/*a=1分配设备*/

请输入作业名、作业所需设备类型和设备相对号\n"

scanf("

%s%s%d"

J,type,&

mm);

allocate(J,type,mm);

/*分配设备*/

break;

case2:

/*a=2回收设备*/

请输入作业名和作业归还的设备类\n"

%s%s"

J,type);

/*输入要回收的作业名及对应的设备类*/

reclaim(J,type);

/*回收设备*/

case3:

/*a=3输出设备类表和设备表的内容*/

输出设备类表!

\n"

/*输出设备类表内容*/

设备类型设备总量空闲好设备起始地址\n"

n;

i++)

%9s%16d%22d%14d\n"

equiptype[i].type,equiptype[i].count,equiptype[i].remain,equiptype[i].address);

输出设备表:

/*输出设备表内容*/

绝对号好/坏已/未分配占用作业名相对号\n"

m;

%3d%11d%15d%15s%9d\n"

equipment[i].number,equipment[i].status,equipment[i].remain,equipment[i].jobname,equipment[i].lnumber);

4、运行结果以及结论。

初始化输入:

可见在设备b回收j1后,设备b的‘已/未分配’变为了0.

(此文档部分内容来源于网络,如有侵权请告知删除,文档可自行编辑修改内容,供参考,感谢您的支持)

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 人文社科 > 法律资料

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2