操作系统实验六_设备管理

合集下载

操作系统的主要功能中设备管理包括

操作系统的主要功能中设备管理包括

操作系统的主要功能中设备管理包括操作系统是计算机系统中的核心软件,为硬件和应用程序之间提供了一个桥梁。

它具有多个主要功能,其中一个关键的功能是设备管理。

设备管理在操作系统中承担着监控、控制和协调计算机系统中各种设备的任务。

本文将介绍操作系统的设备管理功能以及其在计算机系统中的重要性。

设备管理的定义设备管理是指操作系统通过对计算机系统中的各种硬件设备进行管理和控制,使得应用程序能够有效地使用这些设备并实现系统资源的合理分配。

设备管理的任务包括设备的分配和回收、设备驱动程序的控制和设备的错误处理等。

设备分配和回收设备分配是指操作系统将系统中的设备分配给应用程序并为其提供操作权限。

设备的分配通常基于优先级和资源需求等因素进行决策。

操作系统通过设备驱动程序来控制设备并将输入和输出操作传递给设备。

一旦设备分配给应用程序,操作系统负责确保该应用程序独占地使用设备,以避免冲突和资源的浪费。

设备回收是指操作系统在应用程序使用设备完成任务后将设备重新收回并释放其资源。

设备回收的过程包括将设备状态重置为初始状态,并将其重新加入系统的设备池,以待下一次分配。

设备驱动程序的控制设备驱动程序是一种软件模块,负责与特定设备进行交互并控制其操作。

操作系统通过设备驱动程序实现对设备的控制。

设备驱动程序负责处理设备的特定指令和数据,将操作系统或应用程序的请求转换为设备可理解的指令并向设备发送。

它还负责接收设备的响应并将其传递给操作系统或应用程序。

设备驱动程序的控制包括设备的初始化、设备状态的监控和设备的中断处理。

设备初始化包括将设备初始化为工作状态,并为其分配必要的资源和配置信息。

设备状态的监控是指设备驱动程序定期检查设备的状态,以便及时发现和处理设备的故障和异常。

设备的中断处理是指设备驱动程序对设备的中断信号进行处理,以响应设备的事件和请求。

设备的错误处理设备的错误处理是指操作系统对设备错误进行监测和处理。

当设备发生错误时,操作系统会通过设备驱动程序获取设备的错误状态和信息,并采取相应的措施来处理错误。

操作系统第6章(设备管理习题与解答)

操作系统第6章(设备管理习题与解答)

第6章设备管理习题与解答6.1 例题解析例6.2.1 何谓虚拟设备?请说明SPOOLing系统是如何实现虚拟设备的。

解本题的考核要点是虚拟设备的实现方法。

虚拟设备是指利用软件方法,比如SPOOLing系统,把独享设备分割为若干台逻辑上的独占的设备,使用户感受到系统有出若干独占设备在运行。

当然,系统中至少一台拥有物理设备,这是虚拟设备技术的基础。

SPOOLing系统又称“假脱机I/O系统”,其中心思想是,让共享的、高速的、大容量外存储器(比如,磁盘)来模拟若干台独占设备,使系统中的一台或少数几台独占设备变成多台可并行使用的虚拟设备。

SPOOLing系统主要管理外存上的输入井和输出井,以及内存中的输入缓冲区和输出缓冲区。

其管理进程主要有输入和输出进程,负责将输入数据装入到输入井,或者将输出井的数据送出。

它的特点是:提高了 I/O操作的速度;将独占设备改造为共享设备;实现了虚拟设备功能。

例 6.2.2 有关设备管理要领的下列叙述中,( )是不正确的。

A.通道是处理输入、输出的软件B.所有外围设备都由系统统一来管理C.来自通道的I/O中断事件由设备管理负责处理D.编制好的通道程序是存放在主存贮器中的E.由用户给出的设备编号是设备的绝对号解本题的考核要点是设备管理的基本概念。

(1) 通道是计算机上配置的一种专门用于输入输出的设备,是硬件的组成部分。

因此A是错误的。

(2) 目前常见I/O系统其外部设备的驱动和输入输出都由系统统一管理。

因此B是对的。

(3) 设备管理模块中的底层软件中配有专门处理设备中断的处理程序。

通道中断属于设备中断的一种。

因此C是对的。

(4) 通道设备自身只配有一个简单的处理装置(CPU),并不配有存储器,它所运行的通道程序全部来自内存。

因此D是对的。

(5) 系统在初启时为每台物理设备赋予一个绝对号,设备绝对号是相互独立的。

由用户给出的设备号只能是逻辑编号,由系统将逻辑号映射为绝对号。

因此E是错误的。

操作系统实验

操作系统实验

操作系统实验操作系统实验是计算机科学与技术领域非常重要的一门实验课程。

通过操作系统实验,学生可以深入了解操作系统的基本原理和实践技巧,掌握操作系统的设计和开发方法。

本文将介绍操作系统实验的一般内容和实验室环境要求,并详细说明一些常见的操作系统实验内容。

一、实验内容1. 实验环境搭建:操作系统实验通常在实验室中进行。

为了完成实验,学生需要搭建一个操作系统实验环境。

实验环境通常由一个或多个计算机节点组成,每个计算机节点需要安装操作系统实验所需要的软件和驱动程序。

2. 操作系统整体结构分析:学生首先需要通过文献研究和课堂学习,了解操作系统的整体结构和基本原理。

在实验中,学生需要分析和理解操作系统的各个模块之间的功能和相互关系。

3. 进程管理实验:进程是操作系统中最基本的运行单位。

在这个实验中,学生可以通过编写程序并使用系统调用来实现进程的创建、销毁和调度。

学生需要熟悉进程状态转换和调度算法,理解进程间通信和同步机制。

4. 内存管理实验:内存管理是操作系统中非常重要的一个模块。

学生需要实现虚拟内存管理、页面置换算法以及内存分配和回收策略。

通过这个实验,学生可以深入了解虚拟内存管理的原理和实际应用。

5. 文件系统实验:文件系统是操作系统中负责管理文件和目录的模块。

在这个实验中,学生需要实现基本的文件系统功能,如文件的创建、读取和修改。

学生还可以实现进程间的文件共享和保护机制。

6. 设备管理实验:设备管理是操作系统中与硬件设备交互的一个重要模块。

在这个实验中,学生需要实现设备的初始化、打开和关闭功能。

学生还可以实现设备驱动程序,完成对硬件设备的控制。

二、实验室环境要求1. 计算机硬件:实验室需要配备一定数量的计算机节点。

每个计算机节点需要具备足够的计算能力和内存容量,以满足操作系统实验的要求。

2. 操作系统软件:实验室中的计算机节点需要安装操作系统软件,通常使用Linux或者Windows操作系统。

此外,还需要安装相关的开发工具和编程语言环境。

实验六设备管理

实验六设备管理

操作系统实验实验六设备管理学号 02姓名蔡凤武班级电子A班华侨大学电子工程系实验目的1、理解设备管理的概念和任务。

2、掌握独占设备的分配、回收等主要算法的原理并编程实现。

实验内容与基本要求在Windows系统中,编写程序实现对独占设备的分配和回收的模拟,该程序中包括:建立设备类表和设备表、分配设备和回收设备的函数。

实验报告内容1、独占设备的分配、回收等主要算法的原理。

2、程序流程图。

3、程序及注释。

4、运行结果以及结论。

独占设备的主要算法的原理为了提高操作系统的可适应性和扩展性,现代操作系统中都毫无例外地实现了设备独立性,又叫做设备无关性。

设备独立性的含义是:应用程序独立于具体使用的物理设备。

设备分配:1)当进程申请某类设备时,系统先查“设备类表”。

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

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

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

设备回收:作业运行完成,释放设备时,系统首先要查看设备表,比较每一项,找到占用作业名与运行完作业的作业名相同的栏目,将这一栏的“已/未分配”设置为“未分配”,然后将设备表中对应设备类的可使用数量增加1.初始化设备类表流程图源程序#include<> #include<>#include<>#define false 0#define true 1#define n 4#define m 10struct{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个设备*/ype,type)!=0)i++;if(i>=n)/*没有找到该类设备*/{printf("无该类设备,设备分配失败");return(false);}if(equiptype[i].remain<1)/*所需设备现存可用台数不足*/{printf("该类设备不足,分配失败");return(false);}t=equiptype[i].address;/* 取出该类设备在设备表中的起始地址*/ while(!(equipment[t].status==1 && equipment[t].remain==0)) tatus==1) || !(equipment[t].remain==0)表示设备不是好的或者已分配t++;/*填写作业名、相对号,状态改为已分配*/equiptype[i].remain--;equipment[t].remain=1;strcpy(equipment[t].jobname,J);equipment[t].lnumber=mm;return(true);}/*设备分配函数结束*/ype,type)!=0)i++;if(i>=n)/*没有找到该类设备*/{printf("无该类设备,设备回收失败");return(false);}t=equiptype[i].address; /*取出该类设备在设备表中的起始地址*/ j=equiptype[i].count; /*取出该类设备的数量*/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;if(k==0)printf("该作业没有使用该类设备\n");return (true);}/*设备回收函数结束*/void main( ){char J[4];int i,mm,a;char type[10];/*设备类表初始化:*/strcpy(equiptype[0].type,"input");/*输入机*/equiptype[0].count=2;equiptype[0].remain=2;equiptype[0].address=0;strcpy(equiptype[1].type,"printer");/*打印机 */equiptype[1].count=3;equiptype[1].remain=3;equiptype[1].address=2;strcpy(equiptype[2].type,"disk");/*磁盘机*/equiptype[2].count=4;equiptype[2].remain=4;equiptype[2].address=5;strcpy(equiptype[3].type,"tape");/*磁带机*/equiptype[3].count=1;equiptype[3].remain=1;equiptype[3].address=9;/*设备表初始化:*/for(i=0;i<10;i++){equipment[i].number=i;equipment[i].status=1;equipment[i].remain=0;}while(1){printf("\n0-退出,1-分配,2-回收,3-显示");printf("\n选择功能项(0~3):");scanf("%d",&a);switch(a){case 0 : /*a=0程序结束*/exit(0);case 1 : /*a=1分配设备*/printf("输入作业名、作业所需设备类和设备相对号");scanf("%s%s%d",J,type,&mm);allocate(J,type,mm);/*分配设备*/break;case 2: /*a=2回收设备*/printf("输入作业名和作业归还的设备类");scanf("%s%s",J,type);reclaim(J,type);/*回收设备*/break;case 3: /*a=3 输出设备类表和设备表的内容*/printf("\n输出设备类表\n");printf(" 设备类型设备总量空闲好设备\n");for(i=0;i<n;i++)printf("%9s%8d%9d\n",equiptype[i].type,equiptype[i].count,equiptype[i].remain);printf("输出设备表:\n");printf("绝对号好/坏已/未分配占用作业名相对号\n");for(i=0;i<m;i++)printf("%3d%8d%9d%12s%8d\n",equipment[i].number,equipment[i].status,equipment[i].remain,equipment[i].jobname,equipment[i].lnumb er);}}}运行结果界面:选择功能1 分配选择功能3 显示选择功能2 回收结论经过这次试验,使我理解了设备管理的概念,基本掌握了独占设备的分配、回收等主要算法的编程实现,明白了独占设备的分配、回收等主要算法的原理,对操作系统有了更深的理解。

操作系统的主要功能中设备管理包括什么

操作系统的主要功能中设备管理包括什么

操作系统的主要功能中设备管理包括什么操作系统是计算机系统中的核心组件之一,它具有多个重要功能,其中之一是设备管理。

设备管理涉及操作系统如何与计算机硬件设备进行交互,以提供高效的资源分配和访问控制。

本文将讨论操作系统的主要功能中设备管理所包括的内容。

设备管理的概述设备管理是操作系统的一项重要任务,其目标是协调和控制计算机系统中的各种硬件设备。

操作系统的设备管理器负责与设备驱动程序进行通信,管理设备的分配、初始化、调度和释放。

设备管理的主要目的是确保设备的高效使用,提供对设备的适当控制和保护,同时满足用户和应用程序的需求。

设备分配设备分配是设备管理的一项关键任务,它涉及将可用设备分配给应用程序或用户。

设备管理器通过跟踪设备的状态和使用情况来管理设备的分配。

在设备分配中,操作系统需要考虑以下几点:设备资源的请求应用程序或用户可能会请求访问某个设备资源。

操作系统必须确保请求的合法性,并根据设备的可用性和其他限制条件来决定是否满足请求。

设备资源的分配策略设备管理器需要确定如何分配设备资源给多个请求。

它可以使用不同的策略,如先到先得、优先级调度等,根据具体的应用场景和优先级来决定设备资源分配的方式。

设备资源的冲突解决当多个应用程序或用户请求同一个设备资源时,可能会发生冲突。

设备管理器需要解决这些冲突,并确保设备资源的公平分配。

设备初始化与配置设备初始化和配置是设备管理的另一个重要方面。

操作系统负责初始化和配置连接到计算机系统的各种设备。

设备初始化包括以下步骤:设备识别与检测操作系统需要检测新连接的设备并确定其类型和功能。

这个过程通常由设备驱动程序完成,操作系统负责与驱动程序进行通信并解析设备信息。

设备分配与驱动程序加载当检测到新设备后,操作系统将为其分配适当的资源,并加载相应的设备驱动程序。

设备驱动程序负责实现与设备的通信和控制,使操作系统能够对设备进行操作。

设备配置与初始化一旦设备驱动程序加载完成,操作系统将进行设备的配置和初始化。

_设备管理习题及答案

_设备管理习题及答案

第六章设备管理习题一、填空题1.磁带是一种①的设备,它最适合的存取方法是②。

磁盘是一种③的设备,磁盘在转动时经过读/写磁头所形成的圆形轨迹称为④。

【答案】①顺序存取,②顺序存取,③直接存取,④磁道(或柱面)【解析】顺序存取的设备只有在前面的物理块被存取访问过之后,才能存取后续物理块的内容。

如果按随机方式或按键存取方式存取磁带上的文件信息的话,其效率反而会更低,所以顺序存取方法更能发挥磁带这种设备的效率。

磁盘设备是一种典型的直接存取设备,它允许文件系统直接存取磁盘上的任意物理块。

2.从资源分配的角度看,可以把设备分为①设备和②设备;打印机是一种典型的③设备,而磁盘是一种④设备。

【答案】①独享,②共享,③独享,④共享【解析】独享设备:为了保证传递信息的连贯性,通常这类设备一经分配给某个作业,就在作业整个运行期间都为它独占。

多数的低速设备都属于独享设备。

共享设备:是指允许若干个用户同时共享使用的设备。

3.虚拟设备是通过①技术,把②变成能为若干用户③的设备。

【答案】①SPOOLING,②独享,③共享【解析】虚拟设备的提出是为了把原为独享的设备改造成便于共享的设备,以提高设备的利用率。

这种改造就是通过SPOOLING技术来实现的。

SPOOLING可以译为外围设备同时联机操作的意思。

4.UNIX系统中,所有的输入/输出设备都被看成是①。

它们在使用形式上与②相同,但它们的使用是和设备管理程序紧密相连的。

【答案】①特殊文件,②普通文件【解析】在一些操作系统中,常常把设备也看成是文件。

这样的好处是:用户可以用统一的观点去使用设备,并处理存放在设备上的信息。

从这个意义上来说,文件系统在用户和外设之间提供了一个接口。

5.系统中,象键盘、终端、打印机等以①为单位组织和处理信息的设备称为②;而磁盘、磁带等以③为单位组织和处理信息的设备称为④。

【答案】①字符,②字符设备,③块,④块设备6.一个进程只有获得了①、②和所需设备三者之后,才具备了进行I/O操作的物质条件。

操作系统的主要功能中设备管理包括哪些

操作系统的主要功能中设备管理包括哪些

操作系统的主要功能中设备管理包括哪些操作系统是计算机系统中至关重要的一部分,负责管理计算机的各种硬件和软件资源。

其中,设备管理是操作系统的主要功能之一,它涵盖了多个方面,旨在有效地管理和控制计算机系统中的各种设备。

本文将介绍操作系统中设备管理的主要功能。

设备驱动程序调度每个设备都需要对应的设备驱动程序,负责与操作系统进行交互并提供设备的功能。

设备管理的首要任务之一是调度设备驱动程序,确保设备能够被正确地初始化、配置和操作。

设备驱动程序调度策略的选择取决于多个因素,如设备的优先级、请求队列的长度等。

操作系统需要根据这些因素来决定选择哪个驱动程序来服务设备的请求,以提高设备的利用率和系统的性能。

设备分配与释放在多道程序环境下,多个进程可能同时请求访问某个设备。

设备管理的重要任务之一是有效地管理设备的分配与释放。

设备分配的目标是合理分配资源以满足各个进程的设备需求,并避免资源的浪费。

操作系统需要根据进程的优先级和策略来决定设备的分配方式,以确保资源能够得到有效利用。

设备释放的目标是当设备不再被进程使用时,及时释放设备资源以便其他进程使用。

操作系统需要监控设备的使用情况,并在适当的时候将设备资源返还给系统。

设备状态管理设备状态管理是设备管理的关键要素之一。

操作系统需要跟踪每个设备的状态,包括设备是否空闲、是否正在运行、是否发生错误等。

通过设备状态管理,操作系统能够及时检测设备的变化并做出相应的处理。

设备状态管理还包括处理设备的中断、故障和错误。

当设备发生中断或故障时,操作系统需要捕获相应的信号并对其进行处理,以确保系统的稳定性和可靠性。

设备性能优化设备管理还涉及到对设备性能的优化。

操作系统需要通过各种技术手段来提高设备的访问速度和效率。

其中一种常见的优化技术是设备缓存。

操作系统可以使用缓存技术来缓存设备的数据,以减少对设备的访问次数,提高数据的读写速度。

此外,操作系统还可以通过设备调度算法的优化,使得设备能够更加高效地响应进程的请求。

操作系统实验报告模板

操作系统实验报告模板

操作系统实验报告模板一、实验目的本次操作系统实验的主要目的是通过实际操作和观察,深入理解操作系统的核心概念和功能,包括进程管理、内存管理、文件系统、设备管理等方面。

同时,培养学生的动手能力、问题解决能力和团队合作精神,提高对操作系统原理的掌握程度和实际应用能力。

二、实验环境1、操作系统:_____(具体操作系统名称及版本)2、开发工具:_____(如编译器、调试器等)3、硬件环境:_____(处理器型号、内存大小等)三、实验内容(一)进程管理实验1、进程创建与终止使用系统调用创建多个进程,并观察进程的创建过程和资源分配情况。

实现进程的正常终止和异常终止,观察终止时的系统行为。

2、进程调度研究不同的进程调度算法,如先来先服务(FCFS)、短作业优先(SJF)、时间片轮转(RR)等。

通过编程模拟实现这些调度算法,并比较它们的性能。

3、进程同步与互斥利用信号量、互斥锁等机制实现进程之间的同步与互斥。

编写多进程程序,模拟生产者消费者问题、读者写者问题等经典同步场景。

(二)内存管理实验1、内存分配与回收实现不同的内存分配算法,如首次适应算法、最佳适应算法、最坏适应算法等。

观察内存分配和回收的过程,分析算法的优缺点。

2、虚拟内存了解虚拟内存的概念和实现原理。

通过设置页表、进行页面置换等操作,模拟虚拟内存的管理过程。

(三)文件系统实验1、文件操作实现文件的创建、打开、读写、关闭等基本操作。

研究文件的属性(如权限、大小、创建时间等)的设置和获取。

2、目录管理创建、删除目录,遍历目录结构。

实现文件和目录的重命名、移动等操作。

(四)设备管理实验1、设备驱动程序了解设备驱动程序的结构和工作原理。

编写简单的设备驱动程序,实现对特定设备的控制和数据传输。

2、设备分配与回收研究设备分配的策略,如独占式分配、共享式分配等。

实现设备的分配和回收过程,观察系统的资源利用情况。

四、实验步骤(一)进程管理实验步骤1、进程创建与终止编写程序,使用系统调用创建指定数量的进程。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

操作系统课程报告实验六设备管理学号班级教师华侨大学电子工程系实验目的1、理解设备管理的概念和任务。

2、掌握独占设备的分配、回收等主要算法的原理并编程实现。

实验容与基本要求1、在Windows系统中,编写程序实现对独占设备的分配和回收的模拟,该程序中包括:建立设备类表和设备表、分配设备和回收设备的函数。

实验报告容1、独占设备的分配、回收等主要算法的原理。

为了提高操作系统的可适应性和可扩展性,现代操作系统中都毫无例外地实现了设备独立性,又叫做设备无关性。

设备独立性的含义是:应用程序独立于具体使用的物理设备。

为了实现独占设备的分配,系统设置数据表格的方式也不相同,在实验中只要设计合理即可。

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

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

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

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

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

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

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

2、程序流程图。

主程序流程图:设备分配:设备回收:3、程序及注释。

#include<stdio.h>#include<string.h>#include<stdlib.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 lnumber; /*设备相对编号*/int status; /*设备好坏状态*/int remain; /*设备是否已被分配*/char jobname[4]; /*占有设备的作业名*/}equipment[m]; /*系统设备数为m*//**********************子函数:作业设备分配*****************************/allocate(char *J,char *type,int cc){int i,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){int i,t,j,k,nn;i=0;while(i<n&&strcmp(equiptype[i].type,type)!=0) /*查找欲申请归还的设备类型,strcmp函数用于比较equiptype[i].type与type的大小,若相等则返回0*/i++;if(i>=n)/*若没有找到该类设备*/{printf("无该类设备,设备回收失败!");return(false);}t=equiptype[i].address; /*取出该类设备在设备表中的起始地址赋给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");}/**********************主函数*****************************/ void main( ){char J[4];int i,mm,a;char type[10];printf("设备类初始化\n ");for(i=0;i<4;i++) /*输入设备类表初始信息*/{printf("请输入相应设备名称:");scanf("%s",&equiptype[i].type);printf("请输入相应设备的数量:");scanf("%d",&equiptype[i].count);printf("请输入当前空闲设备数量:");scanf("%d",&equiptype[i].remain);printf("请输入设备表起始地址:");scanf("%d",&equiptype[i].address);}for(i=0;i<10;i++) /*初始化设备表*/{equipment[i].number=i;equipment[i].status=1;equipment[i].remain=0;}while(1){printf("\n0-退出,1-分配,2-回收,3-显示"); /*功能选择界面*/printf("\n请选择功能(0-3):");scanf("%d",&a);switch(a){case 0 : /*a=0程序结束*/exit(0);case 1 : /*a=1分配设备*/printf("请输入作业名、作业所需设备类型和设备相对号\n");scanf("%s%s%d",J,type,&mm);allocate(J,type,mm);/*分配设备*/break;case 2: /*a=2回收设备*/printf("请输入作业名和作业归还的设备类\n");scanf("%s%s",J,type);/*输入要回收的作业名及对应的设备类*/reclaim(J,type);/*回收设备*/break;case 3: /*a=3 输出设备类表和设备表的容*/printf("输出设备类表!\n"); /*输出设备类表容*/printf(" 设备类型设备总量空闲好设备起始地址\n");for(i=0;i<n;i++)printf("%9s%16d%22d%14d\n",equiptype[i].type,equiptype[i].count,equiptype[i].remain,equiptype[i].address);printf("输出设备表:\n"); /*输出设备表容*/printf("绝对号好/坏已/未分配占用作业名相对号\n");for(i=0;i<m;i++)printf("%3d%11d%15d%15s%9d\n",equipment[i].number,equipmen t[i].status,equipment[i].remain,equipment[i].jobname,equipment[i].lnumber);}}}4、运行结果以及结论。

初始化输入:设备分配:设备回收:可见在设备b回收j1后,设备b的‘已/未分配’变为了0.。

相关文档
最新文档