1、这里仅仅是一种方案,采用设备类表和设备表。(1) 数据结构操作系统设置“设备分配表”,用来记录计算机系统所配置的独占设备类型、台数以及分配情况。设备分配表可由“设备类表”和“设备表”两部分组成,如下图:(2) 设备分配 当进程申请某类设备时,系统先查“设备类表”如果该类设备的现存台数可以满足申请要求,则从该类设备的“设备表”始址开始依次查该类设备在设备表中的登记项,找出“未分配”的设备分配给进程。分配后要修改设备类表中的现存台数,把分配给进程的设备标志改为“已分配”且填上占用设备的进程名。然后,把设备的绝对号与相对号的对应关系通知用户,以便用户在分配到的设备上装上存储介质。(3) 设备回收当进
2、程执行结束撤离时应归还所占设备,系统根据进程名查设备表,找出进程占用设备的登记栏,把标志修改为“未分配”,清除进程名。同时把回收的设备台数加到设备类表中的现存台数中。2、 程序流程图。主程序流程图:设备分配:设备回收:3、 程序及注释。#includestring.hstdlib.h#define false 0#define true 1#define n 4 /*宏定义,用于修改设备类型数目*/#define m 10 /*宏定义,用于修改设备数目*/struct /*该结构体用于定义设备类表各信息*/ char type10; /*设备类型名*/ int count; /*拥有的设备总台
3、数*/ int remain; /*现存的可用设备台数*/ int address; /*该类设备在设备表中的起始地址*/equiptypen; /*系统设备类型为n*/struct /*该结构体用于定义设备表各信息*/ int number; /*设备绝对编号*/ int lnumber; /*设备相对编号*/ int status; /*设备好坏状态*/ /*设备是否已被分配*/ char jobname4; /*占有设备的作业名*/ equipmentm; /*系统设备数为m*/*子函数:作业设备分配*/ allocate(char *J,char *type,int cc) int i
4、,t,j; i=0; while(i=n) /*若没有找到欲申请设备*/ printf(没有找到欲分配的设备,分配失败!); return(false); if(equiptypei.remain1) /*欲申请设备现存可用台数不足*/ printf(该类设备数量不足,分配失败! return(false); t=equiptypei.address; /* 取出该类设备在设备表中的起始地址赋给t*/while(!(equipmentt.status=1 & equipmentt.remain=0) t+; /*该设备类型起始地址加一*/ equiptypei.remain-; /*剩余设备数
5、减一*/ equipmentt.remain=1; /*状态改为已分配*/ strcpy(equipmentt.jobname,J); /*strcpy为字符串拷贝函数,把J中的字符串拷贝到equipmentt.jobname中*/ equipmentt.lnumber=cc; /*设备相对号写入cc*/ /*子函数:作业设备回收*/ reclaim(char *J,char *type) int i,t,j,k,nn;=0) /*查找欲申请归还的设备类型,strcmp函数用于比较equiptypei.type与type的大小,若相等则返回0*/=n) /*若没有找到该类设备*/ printf
6、(无该类设备,设备回收失败! return(false); /*取出该类设备在设备表中的起始地址赋给t*/ j=equiptypei.count; /*取出该类设备的数量赋给j*/ k=0; nn=t+j; for(;tnn;t+) if(strcmp(equipmentt.jobname,J)=0&equipmentt.remain=1) /*若占用某个设备的作业与欲回收的作业相同且状态为已分配*/ equipmentt.remain=0; /*则将其状态改为未分配*/ k+; /*回收设备计数*/ equiptypei.remain= equiptypei.remain+k; /*该类设备
7、剩余设备数加k*/ if(k=0) /*若回收设备计数值k为0,*/ printf(本作业没有占用这类资源!/n /*主函数*/ void main( ) char J4; int i,mm,a; char type10;设备类初始化n for(i=0;i4;i+) /*输入设备类表初始信息*/ 请输入相应设备名称: scanf(%s,&equiptypei.type);请输入相应设备的数量:%dequiptypei.count);请输入当前空闲设备数量:equiptypei.remain);请输入设备表起始地址:equiptypei.address); for(i=0;10;i+) /*初始
8、化设备表*/ equipmenti.number=i; equipmenti.status=1; equipmenti.remain=0; while(1)n0-退出,1-分配,2-回收,3-显示 /*功能选择界面*/n请选择功能(0-3):a); switch(a) case 0 : /*a=0程序结束*/ exit(0); case 1 : /*a=1分配设备*/请输入作业名、作业所需设备类型和设备相对号n scanf(%s%s%d,J,type,&mm); allocate(J,type,mm); /*分配设备*/ break; case 2: /*a=2回收设备*/请输入作业名和作业归
9、还的设备类n%s%s,J,type); /*输入要回收的作业名及对应的设备类*/ reclaim(J,type); /*回收设备*/ case 3: /*a=3 输出设备类表和设备表的内容*/输出设备类表!n /*输出设备类表内容*/ 设备类型 设备总量 空闲好设备 起始地址nn;i+)%9s%16d%22d%14dn,equiptypei.type,equiptypei.count,equiptypei.remain,equiptypei.address);输出设备表: /*输出设备表内容*/绝对号 好/坏 已/未分配 占用作业名 相对号nm;%3d%11d%15d%15s%9dn,equipmenti.number,equipmenti.status,equipmenti.remain,equipmenti.jobname,equipmenti.lnumber);4、 运行结果以及结论。初始化输入:可见在设备b回收j1后,设备b的已/未分配变为了0.