操作系统实验(六):c实现设备的退出、分配、回收、显示功能

一、【实验目的】
①理解设备管理的概念和任务。
②掌握独占设备的分配、回收等主要算法的原理并编程实现。
2、【实验内容】
在Windows系统中,编写程序实现对独占设备的分配与回收的模拟,该程序中包括:建立设备类表和设备表、分配设备和回收设备的函数。
系统为每一个设备都配置了一张设备控制表,用于记录本设备的情况。每一设备占一个表目,包括:设备状态、是否分配、占有作业名等,如表5-2所示。
作业申请某设备时,先查“设备类表”,如果该类设备的拥有设备数量满足申请要求,则从设备类表中得到该类设备的设备表起始地址,然后找到“设备控制表”中该类设备的起始地址,依次查询该类设备的表项,找到设备状态是“好”且没有被分配的设备分配给作业。分配设备的过程中要修改“设备类表”中可分配设备数量,并且把“设备控制表”中设备“是否分配”项更改为“是”,并填写占有作业名和相对号。

在这里插入图片描述

1 数据结构
struct
{
char type[10];//设备类名
int count;//拥有设备数量
int remain;//现存的可用设备数量
int address;//该类设备在设备表中的起始地址
}equiptype[N];//设备类表定义,假设系统有n个设备类型
struct
{
int number;//设备绝对号
int status;//设备状态可否使用
int IsRemain;//设备是否已分配
char jobname[10];//占有设备的作业名称
int lnumber;//设备相对号
}equipment[M];//设备表定义,假设系统有m个设备

3 实验代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#define N 3//假设系统有3类设备
#define M 5//假设系统有5个设备
#define false 0
#define true 1
struct
{
   
 char type[10];//设备类名
 int count;//拥有设备数量
 int remain;//现存的可用设备数量
 int address;//该类设备在设备表中的起始地址
}equiptype[N];//设备类表定义,假设系统有n个设备类型

struct
{
   
 int number;//设备绝对号
 int status;//设备状态可否使用
 int isRemain;//设备是否已分配
 char jobname[10];//占有设备的作业名称
 int lnumber;//设备相对号
}equipment[M];//设备表定义,假设系统有m个设备
//*********************************函数说明************************************
//设备分配函数
//*****************************************************************************
int allocate(char*job, char*type, int mm)
{
   
 int i=0, t, j;
 //查询该类设备
 while(i<N&&strcmp(equiptype[i].type, type) != 0)
 i++;
 //没有找到该类设备
 if(i >= N)
 {
   
  printf("无该类设备,设备分配请求失败");
  return(false);
 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值