操作系统原理综合实验指导书.docx

上传人:b****4 文档编号:6696148 上传时间:2023-05-10 格式:DOCX 页数:13 大小:59.39KB
下载 相关 举报
操作系统原理综合实验指导书.docx_第1页
第1页 / 共13页
操作系统原理综合实验指导书.docx_第2页
第2页 / 共13页
操作系统原理综合实验指导书.docx_第3页
第3页 / 共13页
操作系统原理综合实验指导书.docx_第4页
第4页 / 共13页
操作系统原理综合实验指导书.docx_第5页
第5页 / 共13页
操作系统原理综合实验指导书.docx_第6页
第6页 / 共13页
操作系统原理综合实验指导书.docx_第7页
第7页 / 共13页
操作系统原理综合实验指导书.docx_第8页
第8页 / 共13页
操作系统原理综合实验指导书.docx_第9页
第9页 / 共13页
操作系统原理综合实验指导书.docx_第10页
第10页 / 共13页
操作系统原理综合实验指导书.docx_第11页
第11页 / 共13页
操作系统原理综合实验指导书.docx_第12页
第12页 / 共13页
操作系统原理综合实验指导书.docx_第13页
第13页 / 共13页
亲,该文档总共13页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

操作系统原理综合实验指导书.docx

《操作系统原理综合实验指导书.docx》由会员分享,可在线阅读,更多相关《操作系统原理综合实验指导书.docx(13页珍藏版)》请在冰点文库上搜索。

操作系统原理综合实验指导书.docx

操作系统原理综合实验指导书

 

《操作系统原理综合实验B》

实验指导书

一、 单处理器系统的进程调度

1.实验目的

在采用多道程序设计的系统中,往往有若干个进程同时处于就绪状态。

当就绪进程个数大于处理器数时,就必须依照某种策略来决定哪些进程优先占用处理器。

本实验模拟在单处理器情况下的处理器调度,帮助学生加深了解处理器调度的工作。

2.实验内容与要求

(1)设计多个进程并发执行的模拟调度程序,每个程序由一个PCB表示。

(2)模拟调度程序可任选两种调度算法之一实现。

(3)程序执行中应能在屏幕上显示出各进程的状态变化,以便于观察调度的整个过程。

3.实验说明

本实验有两个题,学生可选择其中的一题做实验。

第一题:

设计一个按优先数调度算法实现处理器调度的程序。

(1)假定系统有五个进程,每一个进程用一个进程控制块PCB来代表,进程控制块的格式为:

进程名

指针

要求运行时间

优先数

状态

其中,进程名——作为进程的标识,假设五个进程的进程名分别为P1,P2,P3,P4,P5。

指针——按优先数的大小把五个进程连成队列,用指针指出下一个进程的进程控制块的首地址,最后一个进程中的指针为“0”。

要求运行时间——假设进程需要运行的单位时间数。

优先数——赋予进程的优先数,调度时总是选取优先数大的进程先执行。

状态——可假设有两种状态,“就绪”状态和“结束”状态。

五个进程的初始状态都为“就绪”,用“R”表示,当一个进程运行结束后,它的状态为“结束”,用“E”表示。

(2)在每次运行你所设计的处理器调度程序之前,为每个进程任意确定它的“优先数”和“要求运行时间”。

(3)为了调度方便,把五个进程按给定的优先数从大到小连成队列。

用一单元指出队首进程,用指针指出队列的连接情况。

例:

队首标志

K2

K1

P1

K2

P2

K3

P3

K4

P4

K5

P5

0

K4

K5

K3

K1

2

3

1

2

4

1

5

3

4

2

R

R

R

R

R

PCB1

PCB2

PCB3

PCB4

PCB5

(4)处理器调度总是选队首进程运行。

采用动态改变优先数的办法,进程每运行一次优先数就减“1”。

由于本实验是模拟处理器调度,所以,对被选中的进程并不实际的启动运行,而是执行:

优先数-1

要求运行时间-1

来模拟进程的一次运行。

提醒注意的是:

在实际的系统中,当一个进程被选中运行时,必须恢复进程的现场,让它占有处理器运行,直到出现等待事件或运行结束。

在这里省去了这些工作。

(5)进程运行一次后,若要求运行时间0,则再将它加入队列(按优先数大小插入,且置队首标志);若要求运行时间=0,则把它的状态修改成“结束”(E),且退出队列。

(6)若“就绪”状态的进程队列不为空,则重复上面(4)和(5)的步骤,直到所有进程都成为“结束”状态。

(7)在所设计的程序中应有显示或打印语句,能显示或打印每次被选中进程的进程名以及运行一次后进程队列的变化。

(8)为五个进程任意确定一组“优先数”和“要求运行时间”,启动所设计的处理器调度程序,显示或打印逐次被选中进程的进程名以及进程控制块的动态变化过程。

第二题:

设计一个按时间片轮转法实现处理器调度的程序。

(1)假定系统有五个进程,每一个进程用一个进程控制块PCB来代表。

进程控制块的格式为:

进程名

指针

要求运行时间

已运行时间

状态

其中,进程名——作为进程的标识,假设五个进程的进程名分别为Q1,Q2,Q3,Q4,Q5。

指针——进程按顺序排成循环队列,用指针指出下一个进程的进程控制块的首地址,最后一个进程的指针指出第一个进程的进程控制块首地址。

要求运行时间——假设进程需要运行的单位时间数。

已运行时间——假设进程已经运行的单位时间数,初始值为“0”。

状态——有两种状态,“就绪”和“结束”,初始状态都为“就绪”,用“R”表示。

当一个进程运行结束后,它的状态为“结束”,用“E”表示。

(2)每次运行所设计的处理器调度程序前,为每个进程任意确定它的“要求运行时间”。

(3)把五个进程按顺序排成循环队列,用指针指出队列连接情况。

另用一标志单元记录轮到运行的进程。

例如,当前轮到P2执行,则有:

标志单元

K2

K1

Q1

K2

Q2

K3

Q3

K4

Q4

K5

Q5

K2

K3

K4

K5

K1

2

3

1

2

4

1

0

0

0

0

R

R

R

R

R

PCB1

PCB2

PCB3

PCB4

PCB5

(4)处理器调度总是选择标志单元指示的进程运行。

由于本实验是模拟处理器调度的功能,所以,对被选中的进程并不实际的启动运行,而是执行:

已运行时间+1

来模拟进程的一次运行,表示进程已经运行过一个单位的时间。

请同学注意:

在实际的系统中,当一个进程被选中运行时,必须置上该进程可以运行的时间片值,以及恢复进程的现场,让它占有处理器运行,直到出现等待事件或运行满一个时间片。

在这时省去了这些工作,仅用“已运行时间+1”来表示进程已经运行满一个时间片。

(5)进程运行一次后,应把该进程的进程控制块中的指针值送到标志单元,以指示下一个轮到运行的进程。

同时,应判断该进程的要求运行时间与已运行时间,若该进程的要求运行时间已运行时间,则表示它尚未执行结束,应待到下一轮时再运行。

若该进程的要求运行时间=已运行时间,则表示它已经执行结束,应指导它的状态修改成“结束”(E)且退出队列。

此时,应把该进程的进程控制块中的指针值送到前面一个进程的指针位置。

(6)若“就绪”状态的进程队列不为空,则重复上面的(4)和(5)的步骤,直到所有的进程都成为“结束”状态。

(7)在所设计的程序中应有显示或打印语句,能显示或打印每次选中进程的进程名以及运行一次后进程队列的变化。

(8)为五个进程任意确定一组“要求运行时间”,启动所设计的处理器调度程序,显示或打印逐次被选中的进程名以及进程控制块的动态变化过程。

4. 实验报告

(1)实验题目。

(2)程序中使用的数据结构及符号说明。

(3)流程图。

(4)打印一份源程序并附上注释。

(5)打印程序运行时的初值和运行结果。

要求如下:

ⅰ进程控制块的初始状态。

ⅱ选中运行的进程名以及选中进程运行后的各进程控制块状态。

对于ⅱ要求每选中一个进程运行后都要打印。

二、 批处理系统中作业调度

1.实验目的

加深对作业调度算法的理解。

2.实验内容

此实验模拟批处理系统中的作业调度,并采用响应比高者优先算法作为作业调度算法。

3.实验说明

从输入井中选择作业读入内存,使其获得处理器,得到运行的机会,即为作业调度。

输入井中的作业用“作业控制块”(JCB)标识,为了进行作业调度,将作业控制块组成一个队列,这个队列称为后备队列。

模拟实验中没有实际作业,作业控制块中的信息内容只使用了模拟实验中需要的数据。

作业控制块中包括作业名、作业大小、所需打印机台数、所需磁带机数量、作业估计执行时间、作业等待时间、指向下一个作业控制块的指针等内容。

将作业控制块组成一个队列,实验中采用动态链表的方式模拟作业的后备队列。

作业控制块采用结构型数据模拟。

模拟实验中,主存采用可移动的可变分区管理方法,即只要主存空闲区总和比作业大就可以满足作业对主存的需求。

对打印机和磁带机这两种独占设备采用静态分配法,即作业执行前必须获得所需资源,并且执行完才归还。

实验中作业的调度采用响应比高者优先算法。

响应比为作业的等待时间和作业估计执行时间之比。

首先计算出输入井中满足条件的作业的响应比,从中选择响应比最高的一个作业装入主存储器,分配资源。

由于是模拟实验,可将作业控制块出队装入主存储器的工作用输出作业名模拟,同时修改系统的资源数量。

模拟实验时,可以首先假设系统的资源情况。

假设系统资源只有主存64MB、磁带机4台、打印机2台,然后手工输入某个时刻输入井中的各个作业情况,最后进行作业调度,并将结果输出。

批处理系统中的作业调度模拟程序主要由创建作业队列的程序段(在主函数中)和作业调度函数组成。

4.参考程序

系统中主要数据结构和变量的意义见注释。

#include "stdlib.h"

typedef struct jcb

{

char name[4]; /*作业名*/

int length; /*作业长度,所需主存大小*/

int printer; /*作业执行所需打印机的数量*/

int tape; /*作业执行所需磁带机的数量*/

int runtime; /*作业估计的执行时间*/

int waittime; /*作业在输入井中的等待时间*/

struct jcb *next;/*指向下一个作业控制块的指针*/

}JCB; /*作业控制块类型定义*/

JCB *head; /*作业队列头指针定义*/

int tape,printer;

long memory;

 

三、银行家算法

1. 实验目的和要求

银行家算法是避免死锁的一种重要方法,要求编写和调试一个简单的银行家算法程序。

加深了解有关资源申请、避免死锁等概念,并体会和了解死锁和避免死锁的具体实施方法。

2. 实验内容

1.设计进程对各类资源最大申请表示及初值确定。

2.设定系统提供资源初始状况。

3.设定每次某个进程对各类资源的申请表示。

4.编制程序,依据银行家算法,决定其申请是否得到满足。

3.实验说明

1.数据结构

假设有M个进程N类资源,则有如下数据结构:

MAX[M*N] M个进程对N类资源的最大需求量

AVAILABLE[N]系统可用资源数

ALLOCATION[M*N]M个进程已经得到N类资源的资源量

NEED[M*N] M个进程还需要N类资源的资源量

2.银行家算法

设进程I提出请求Request[N],则银行家算法按如下规则进行判断。

(1)如果Request[N]<=NEED[I,N],则转

(2);否则,出错。

(2)如果Request[N]<=AVAILABLE,则转(3);否则,出错。

(3)系统试探分配资源,修改相关数据:

AVAILABLE=AVAILABLE-REQUEST

ALLOCATION=ALLOCATION+REQUEST

NEED=NEED-REQUEST

(4)系统执行安全性检查,如安全,则分配成立;否则试探险性分配作废,系统恢复原状,进程等待。

3.安全性检查

(1)设置两个工作向量WORK=AVAILABLE;FINISH[M]=FALSE

(2)从进程集合中找到一个满足下述条件的进程,

FINISH[i]=FALSE

NEED<=WORK

如找到,执行(3);否则,执行(4)

(3)设进程获得资源,可顺利执行,直至完成,从而释放资源。

WORK=WORK+ALLOCATION

FINISH=TRUE

GO TO 2

(4)如所有的进程Finish[M]=true,则表示安全;否则系统不安全。

4. 参考程序

#include "string.h"

#include "iostream.h"

#define M 5 //总进程数

#define N 3 //总资源数

#define FALSE 0

#define TRUE 1

//M个进程对N类资源最大资源需求量

int MAX[M][N]={{7,5,3},{3,2,2},{9,0,2},{2,2,2},{4,3,3}};

//系统可用资源数

int AVAILABLE[N]={10,5,7}; 

//M个进程已经得到N类资源的资源量

int ALLOCATION[M][N]={{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0}};

//M个进程还需要N类资源的资源量

int NEED[M][N]={{7,5,3},{3,2,2},{9,0,2},{2,2,2},{4,3,3}};

int Request[N]={0,0,0};

 

四、 主存储器空间的分配和回收

1.实验目的

一个好的计算机系统不仅要有一个足够容量的、存取速度高的、稳定可靠的主存储器,而且要能合理地分配和使用这些存储空间。

当用户提出申请存储器空间时,存储管理必须根据申请者的要求,按一定的策略分析主存空间的使用情况,找出足够的空闲区域分配给申请者。

当作业撤离或主动归还主存资源时,则存储管理要收回作业占用的主存空间或归还部分主存空间。

主存的分配和回收的实现虽与主存储器的管理方式有关的,通过本实验帮助学生理解在不同的存储管理方式下应怎样实现主存空间的分配和回收。

2.实验内容

本实验模拟在两种存储管理方式下的主存分配和回收。

3.提示与讲解

本实验有两个题,学生可选择其中的一题做实验。

第一题:

在可变分区管理方式下采用最先适应算法实现主存分配和实现主存回收。

可变分区方式是按作业需要的主存空间大小来分割分区的。

当要装入一个作业时,根据作业需要的主存量查看是否有足够的空闲空间,若有,则按需要量分割一个分区分配给该作业;若无,则作业不能装入。

随着作业的装入、撤离,主存空间被分成许多个分区,有的分区被作业占用,而有的分区是空闲的。

例如:

0

5k

10k

14k

26k

32k

 

128k

操作系统

作业1

作业3

空闲区

作业2

空闲区

为了说明哪些区是空闲的,可以用来装入新作业,必须要有一张空闲区说明表,格式如下:

起址

长度

状态

第一栏

14K

12K

未分配

第二栏

32K

96K

未分配

空表目

空表目

其中,起址——指出一个空闲区的主存起始地址。

长度——指出从起始地址开始的一个连续空闲的长度。

状态——有两种状态,一种是“未分配”状态,指出对应的由起址指出的某个长度的区域是空闲区;另一种是“空表目”状态,表示表中对应的登记项目是空白(无效),可用来登记新的空闲区(例如,作业撤离后,它所占的区域就成了空闲区,应找一个“空表目”栏登记归还区的起址和长度且修改状态)。

由于分区的个数不定,所以空闲区说明表中应有适量的状态为“空表目”的登记栏目,否则造成表格“溢出”无法登记。

上述的这张说明表的登记情况是按提示

(1)中的例所装入的三个作业占用的主存区域后填写的。

(2)当有一个新作业要求装入主存时,必须查空闲区说明表,从中找出一个足够大的空闲区。

有时找到的空闲区可能大于作业需要量,这时应把原来的空闲区变成两部分:

一部分分给作业占用;另一部分又成为一个较小的空闲区。

为了尽量减少由于分割造成的空闲区,而尽量保存高地址部分有较大的连续空闲区域,以利于大型作业的装入。

为此,在空闲区说明表中,把每个空闲区按其地址顺序登记,即每个后继的空闲区其起始地址总是比前者大。

为了方便查找还可使表格“紧缩”,总是让“空表目”栏集中在表格的后部。

(3)采用最先适应算法(顺序分配算法)分配主存空间。

按照作业的需要量,查空闲区说明表,顺序查看登记栏,找到第一个能满足要求的空闲区。

当空闲区大于需要量时,一部分用来装入作业,另一部分仍为空闲区登记在空闲区说明表中。

由于本实验是模拟主存的分配,所以把主存区分配给作业后并不实际启动装入程序装入作业,而用输出“分配情况”来代替。

最先适应分配算法如图4-1。

(4)当一个作业执行结束撤离时,作业所占的区域应该归还,归还的区域如果与其它空闲区相邻,则应合成一个较大的空闲区,登记在空闲区说明表中。

例如,在提示

(1)中列举的情况下,如果作业2撤离,归还所占主存区域时,应与上、下相邻的空闲区一起合成一个大的空闲区登记在空闲区说明表中。

归还主存时的回收算法如图4-2。

(5)请按最先适应算法设计主存分配和回收的程序。

然后按

(1)中假设主存中已装入三个作业,且形成两个空闲区,确定空闲区说明表的初值。

现有一个需要主存量为6K的作业4申请装入主存;然后作业3撤离;再作业2撤离。

请你为它们进行主存分配和回收,把空闲区说明表的初值以及每次分配或回收后的变化显示出来或打印出来。

第二题:

在分页式管理方式下采用位示图来表示主存分配情况,实现主存空间的分配和回收。

(1)分页式存储器把主存分成大小相等的若干块,作业的信息也按块的大小分页,作业装入主存时可把作业的信息按页分散存放在主存的空闲块中,为了说明主存中哪些块已经被占用,哪些块是尚未分配的空闲块,可用一张位示图来指出。

位示图可由若干存储单元来构成,其中每一位与一个物理块对应,用0/1表示对应块为空闲/已占用。

(2)假设某系统的主存被分成大小相等的64块,则位示图可用8个字节来构成,另用一单元记录当前空闲块数。

如果已有第0,1,4,5,6,9,11,13,24,31,共10个主存块被占用了,那么位示图情况如下:

字位

节数

 

0

 

1

 

2

 

3

 

4

 

5

 

6

 

7

0

1

1

0

0

1

1

1

0

1

0

1

0

1

0

1

0

0

2

0

0

0

0

0

0

0

0

3

1

0

0

0

0

0

0

1

4

0

0

0

0

0

0

0

0

5

0

0

0

0

0

0

0

0

6

0

0

0

0

0

0

0

0

7

0

0

0

0

0

0

0

0

图4-1最先适应分配模拟算法

图4-2主存回收算法

(3)当要装入一个作业时,根据作业对主存的需要量,先查当前空闲块数是否能满足作业要求,若不能满足则输出分配不成功。

若能满足,则查位示图,找出为“0”的一些位,置上占用标志“1”,从“当前空闲块数”中减去本次占用块数。

按找到的计算出对应的块号,其计算公式为:

块号=j8+i

其中,j表示找到的是第n个字节,I表示对应的是第n位。

根据分配给作业的块号,为作业建立一张页表,页表格式:

页号

块号

0

1

2

(4)当一个作业执行结束,归还主存时,根据该作业的页表可以知道应归还的块号,由块号可计算出在位示图中的对应位置,把对应位的占用标志清成“0”,表示对应的块已成为空闲块。

归还的块数加入到当前空闲块数中。

由块号计算在位示图中的位置的公式如下:

字节号j=[块号/8]([]表示取整)

位数i={块号/8}({}表示取余)

(5)设计实现主存分配和回收的程序。

假定位示图的初始状态如

(2)所述,现有一信息量为5页的作业要装入,运行你所设计的分配程序,为作业分配主存且建立页表(格式如(3)所述)。

然后假定有另一作业执行结束,它占用的块号为第4,5,6和31块,运行你所设计的回收程序,收回作业归还的主存块。

要求能显示和打印分配或回收前后的位示图和当前空闲块数,对完成一次分配后还要显示或打印为作业建立的页表。

4.实验报告

(1)实验题目。

(2)程序中使用的数据结构及符号说明。

(3)流程图。

(4)打印一份源程序并附上注释。

(5)打印程序运行时的初值和运行结果,要求如下:

第一题:

打印空闲区说明表的初始状态,作业4的申请量以及为作业4分配后的空闲区说明表状态;再依次打印作业3和作业2的归还量以及回收作业3,作业2所占主存后的空闲区说明表。

第二题:

打印位示图和当前空闲块数的初值;要求装入的作业对主存的申请量,为作业分配后的位示图、当前空闲块数和页表;作业归还的块号、回收作业所占主存后的位示图和当前空闲块数。

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

当前位置:首页 > 工程科技

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

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