操作系统经典习题教学内容

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

习题:

1.进程同步,信号量机制实现

设有6个程序s1,…, s6,它们在并发系统中执行时如图所示的制约关系,试用wait和signal原语来实现它们之间的同步。(10分)

Var a, b, c, d, e, f, g, h; semaphore:= 0, 0, 0, 0, 0, 0, 0;

begin

parbegin

begin S1; signal(a); signal(b);signal(c); end;

begin wait(a); S2; signal(d); end;

begin wait(b); S3; signal(f); end;

begin wait(c); S4; signal(g); end;

begin wait(d); S5; signal(e); end;

begin wait(e); wait(f); wait(g); S6; end;

parend

end

2.进程同步,信号量机制实现。详见上课讲的例题

3.有如下进程,后一个依次比前一个晚一个时间单位到达,

(1)画出下列调度算法下的调度时间图:FCFS、抢占式\非抢占式SPF、抢占式\非抢占式HPF、HRRN和RR(q=1,q=2)

(2)对于上述每种算法,各个作业的周转时间是多少?平均周转时间是多少?

(3)对于上述每种算法,各个作业的带权周转时间和平均带权周转时间各是多少?

相应比=【(等待时间=现在时刻减去到达时间)+服务时间】/服务时间

4.作出页式存储管理系统中地址变换机构图。已知某作业页表如下:

0 2

1 5

2 9

3 8

试借助地址变换机构图求出逻辑地址对应的物理地址(1页为1024字节)

(1) 2968 (2)4599 (3)0FCCH

解:分析逻辑地址除以页面大小=商是页号:余数是页内地址偏移根据页号查找页表中的页号判断是(缺页中断,越界中断...)物理地址=块号*块大小+地址偏移

其中十六进制的直接转换为四位二进制计算

1.2968/1024=

2...920 物理地址:9*1024+920=10136

2.4599/1024=4...503 越界中断

3.0FCCH二进制为:111111001100/2^10=11 (111001100)

物理地址:8*1024+972=9164

5.有一虚拟存储系统,某作业运行中使用的操作数所在的页号依次

为:4 3 2 1 4 3 5 4 3 2 5 1 2 4 2 5 3 4 1 5

在内存中为该作业进程开辟3个物理块。分别采用FIFO、LRU页

面淘汰算法,图示该作业运行的置换情况,并计算相应的缺页率?

1.最佳置换算法是置换以后永不使用的页面即“向后看”

4 3 2 1 4 3

5 4 3 2 5 1 2 4 2 5 3 4 1 5 4 4 4 1 1 1 5 5 5 4 4 4 1

3 3 3

4 4 4 2 2 2

5 5 5

2 2 2

3 3 3 1 1 1 3 3

2.FIFO是淘汰最先进入的页面

缺页率:(7/20)*100%=35%

LRU算法是淘汰选择最近久未使用的页面就是“向前看”

4 3 2 1 4 3

5 4 3 2 5 1 2 4 2 5 3 4 1 5

4 4 4 1 1 1

5 2 2 2 2 2 2 4 4 4

3 3 3

4 4 4 4

5 5 4 4 3 3 3 5

2 2 2

3 3 3 3 1 1 5 5 5 1 1

缺页率:(4/20)*100%=20%

6.假设磁盘有200个磁道(编号为0~199)的移动头磁盘,在完成

了磁道125处的请求后,当前正在磁道号为143的磁道处为一个请求服务。若请求队列以FIFO次序存放,即86,147,91,177,94,150,102,175,130。对下列每一中磁盘调度算法,若要满足这些要求,则总的磁头移动次数为多少 (后两种要求,读写头朝着磁道号增大的方向移动) ?

(1)FCFS (2)SSTF (3)SCAN (4)CSCAN

首先根据题意可知:磁头正由低磁道号向高磁道号方向移动。

fcfs: 顺序是:143--86--147--91--177--94--150--102--175--130 (143-86)+(147-86)+(147-91)+(177-91)+(177-94)+(150-94)+(150-10 2)+(175-102)+(175-130)=565

sstf:顺序是:143--147--150--130--102--94--91--86--175--177 (147-143)+(150-147)+(150-130)+(130-102)+(102-94)+(94-91) +(91-86)+(175-86)+(177-175)=162

scan:顺序是:先移动到最大柱面号(199)再移动到最小柱面号(0)再移动到130 (199-143)+(199-0)+(130-0)=385

例:假定某磁盘共有200个柱面,编号为0-199,如果在为访问143号柱面的请求者服务后,当前正在为访问125号柱面的请求服务,同时有若干请求者在等待服务,它们每次要访问的柱面号为86,147,91,177,94,150,102,175,130

1、先来先服务算法(FCFS)First Come First Service

这是一种比较简单的磁盘调度算法。它根据进程请求访问磁盘的先后次序进行调度。此算法的优点是公平、简单,且每个进程的请求都能依次得到处理,不会出现某一进程的请求长期得不到满足的情况。此算法由于未对寻道进行优化,在对磁盘的访问请求比较多的情况下,此算法将降低设备服务的吞吐量,致使平均寻道时间可能较长,但各进程得到服务的响应时间的变化幅度较小。

相关文档
最新文档