操作系统经典习题..
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
习题:
1.进程同步,信号量机制实现
设有6个程序s1,…, s6,它们在并发系统中执行时如图所示的制约关系,试用wait和signal原语来实现它们之间的同步。(10分)
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 越界中断
物理地址: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
这是一种比较简单的磁盘调度算法。它根据进程请求访问磁盘的先后次序进行调度。此算法的优点是公平、简单,且每个进程的请求都能依次得到处理,不会出现某一进程的请求长期得不到满足的情况。此算法由于未对寻道进行优化,在对磁盘的访问请求比较多的情况下,此算法将降低设备服务的吞吐量,致使平均寻道时间可能较长,但各进程得到服务的响应时间的变化幅度较小。
先来先服务(125)
2、最短寻道时间优先算法(SSTF)Shortest Seek Time First
该算法选择这样的进程,其要求访问的磁道与当前磁头所在的磁道距离最近,以使每次的寻道时间最短,该算法可以得到比较好的吞吐量,但却不能保证平均寻道时间最短。其缺点是对用户的服务请求的响应机会不是均等的,因而导致响应时间的变化幅度很大。在服务请求很多的情况下,对内外边缘磁道的请求将会无限期的被延迟,有些请求的响应时间将不可预