1、习题:1. 进程同步,信号量机制实现设有 6 个程序 s1, s6,它们在并发系统中执行时如图所示的制约关系,试用 wait 和 signal 原语来实现它们之间的同步。 (10分)Var a, b, c, d, e, f, g, h; semaphore:= 0, 0, 0, 0, 0, 0, 0;beginparbeginbegin 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; sig
2、nal(g); end;begin wait(d); S5; signal(e); end;begin wait(e); wait(f); wait(g); S6; end;parendend2. 进程同步,信号量机制实现。详见上课讲的例题3. 有如下进程,后一个依次比前一个晚一个时间单位到达,作业 运行时间 优先级 A 3 3 B 1 1 S1S2S4S3S5S6C 2 5D 1 4 E 5 6 (1)画出下列调度算法下的调度时间图:FCFS、抢占式非抢占式 SPF、抢占式 非抢占式 HPF、HRRN 和 RR(q=1,q=2)(2)对于上述每种算法,各个作业的周转时间是多少?平均周转时间是
3、多少? (3)对于上述每种算法,各个作业的带权周转时间和平均带权周转时间各是多少?相应比=【(等待时间=现在时刻减去到达时间)+服务时间】/服务时间作业 A B C D E 平均到达时间 0 1 2 3 4算法服务时间 3 1 2 1 5完成时间 3 4 6 7 12周转时间 3 3 4 4 8 4.4FCFS带权周转时间 1 3 2 4 1.6 2.32完成时间 3 4 7 5 12周转时间 3 3 5 2 8 4.2SPF(非)带权周转时间 1 3 2.5 2 1.6 2.02完成时间 3 11 5 12 10周转时间 3 10 3 9 6 6.2SPF(抢)带权周转时间 1 10 1.5
4、 9 1.2 4.54完成时间 3 11 5 12 10周转时间 3 10 3 9 6 6.2HPF(非)带权周转时间 1 10 1.5 9 1.2 4.54完成时间 11 12 4 10 9周转时间 11 11 2 7 5 7.2HPF(抢)带权周转时间 11/3 11 1 7 1 4.72完成时间 3 4 6 7 12周转时间 3 3 4 4 8 4.4HRRN带权周转时间 1 3 2 4 1.6 2.32完成时间 7 2 8 5 12周转时间 7 1 6 2 8 4.8RR(r=1)带权周转时间 7/3 1 3 2 1.6 1.924. 作出页式存储管理系统中地址变换机构图。已知某作业页
5、表如下:0 21 52 9 3 8试借助地址变换机构图求出逻辑地址对应的物理地址(1 页为1024 字节)(1) 2968 (2)4599 (3)0FCCH解:分析逻辑地址除以页面大小=商是页号:余数是页内地址偏移根据页号查找页表中的页号判断是(缺页中断,越界中断.)物理地址=块号*块大小+地址偏移其中十六进制的直接转换为四位二进制计算1.2968/1024=2.920 物理地址:9*1024+920=101362.4599/1024=4.503 越界中断3.0FCCH 二进制为:111111001100/210=11.111001100物理地址:8*1024+972=91645. 有一虚拟存
6、储系统,某作业运行中使用的操作数所在的页号依次为:4 3 2 1 4 3 5 4 3 2 5 1 2 4 2 5 3 4 1 5在内存中为该作业进程开辟 3 个物理块。分别采用 FIFO、LRU页面淘汰算法,图示该作业运行的置换情况,并计算相应的缺页率?1.最佳置换算法是置换以后永不使用的页面即“向后看”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 54 3 2 1 4 3 5 4 3 2 5 1 2 4 2 5 3 4 1 54 4 4
7、1 1 1 5 5 5 4 4 4 13 3 3 4 4 4 2 2 2 5 5 52 2 2 3 3 3 1 1 1 3 34 4 4 1 1 1 5 2 2 2 2 2 2 4 4 43 3 3 4 4 4 4 5 5 4 4 3 3 3 52 2 2 3 3 3 3 1 1 5 5 5 1 1缺页率:(4/20)*100%=20%6. 假设磁盘有 200 个磁道(编号为 0199)的移动头磁盘,在完成了磁道 125 处的请求后,当前正在磁道号为 143 的磁道处为一个请求服务。若请求队列以 FIFO 次序存放,即86,147,91,177,94,150,102,175,130。对下列每一
8、中磁盘调度算法,若要满足这些要求,则总的磁头移动次数为多少 (后两种要求,读写头朝着磁道号增大的方向移动) ?(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-102)+(175-102)+(175-130)=565sstf:顺序是:143-147-150-130-102-94-91-86-175-177(147-143
9、)+(150-147)+(150-130)+(130-102)+(102-94)+(94-91)+(91-86)+(175-86)+(177-175)=162scan:顺序是:先移动到最大柱面号(199)再移动到最小柱面号 (0)再移动到130 (199-143)+(199-0)+(130-0)=385例:假定某磁盘共有200 个柱面,编号为 0-199,如果在为访问 143号柱面的请求者服务后,当前正在为访问125 号柱面的请求服务,同时有若干请求者在等待服务,它们每次要访问的柱面号为 86,147,91 ,177 ,94,150,102 ,175,1301、先来先服务算法(FCFS)Fir
10、st Come First Service这是一种比较简单的磁盘调度算法。它根据进程请求访问磁盘的先后次序进行调度。此算法的优点是公平、简单,且每个进程的请求都能依次得到处理,不会出现某一进程的请求长期得不到满足的情况。此算法由于未对寻道进行优化,在对磁盘的访问请求比较多的情况下,此算法将降低设备服务的吞吐量,致使平均寻道时间可能较长,但各进程得到服务的响应时间的变化幅度较小。先来先服务 (125 )86.147.91.177.94.150.102.175.1302、最短寻道时间优先算法(SSTF) Shortest Seek Time First该算法选择这样的进程,其要求访问的磁道与当前磁
11、头所在的磁道距离最近,以使每次的寻道时间最短,该算法可以得到比较好的吞吐量,但却不能保证平均寻道时间最短。其缺点是对用户的服务请求的响应机会不是均等的,因而导致响应时间的变化幅度很大。在服务请求很多的情况下,对内外边缘磁道的请求将会无限期的被延迟,有些请求的响应时间将不可预期。最短寻道时间优先(125 )130.147.150.175.177.102.94.91.863、扫描算法(SCAN )电梯调度扫描算法不仅考虑到欲访问的磁道与当前磁道的距离,更优先考虑的是磁头的当前移动方向。例如,当磁头正在自里向外移动时,扫描算法所选择的下一个访问对象应是其欲访问的磁道既在当前磁道之外,又是距离最近的。
12、这样自里向外地访问,直到再无更外的磁道需要访问才将磁臂换向,自外向里移动。这时,同样也是每次选择这样的进程来调度,即其要访问的磁道,在当前磁道之内,从而避免了饥饿现象的出现。由于这种算法中磁头移动的规律颇似电梯的运行,故又称为电梯调度算法。此算法基本上克服了最短寻道时间优先算法的服务集中于中间磁道和响应时间变化比较大的缺点,而具有最短寻道时间优先算法的优点即吞吐量较大,平均响应时间较小,但由于是摆动式的扫描方法,两侧磁道被访问的频率仍低于中间磁道。电梯调度(125 )102.94.91.86.130.147.150.175.1774、循环扫描算法(CSCAN )循环扫描算法是对扫描算法的改进。
13、如果对磁道的访问请求是均匀分布的,当磁头到达磁盘的一端,并反向运动时落在磁头之后的访问请求相对较少。这是由于这些磁道刚被处理,而磁盘另一端的请求密度相当高,且这些访问请求等待的时间较长,为了解决这种情况,循环扫描算法规定磁头单向移动。例如,只自里向外移动,当磁头移到最外的被访问磁道时,磁头立即返回到最里的欲访磁道,即将最小磁道号紧接着最大磁道号构成循环,进行扫描。循环扫描 (125 )130.147.150.175.177.86.91.94.1027. 说明文件物理结构中显式链接的原理,并计算一个 200M 的硬盘(盘块大小为 1KB)其 FAT 表的大小。解:盘块=容量/盘块大小 200M/
14、1KB=200K(个)表项大小满足为四位二进制的整数倍又因为:128K200K256K 故 表项大小为 2.5 个字节FAT 表的大小=表项大小*表项数=200*2.5=500KB解:由题目所给条件可知,硬盘大小为540M,磁盘块的大小为1K,所以该硬盘共有盘块:540M/1K=540K(个)又512K540K1024K故540K 个盘块号要用20位二进制表示,即文件分配表的每个表目为2.5个字节。FAT 要占用的存储空间总数为:2.5540K=1350K当硬盘大小为1.2G,硬盘共有盘块:1.2G/1K=1.2M(个)又1M 1.2M2M故1.2M 个盘块号要用31位二进制表示。为方便文件分
15、配表的存取,每个表目用32 位二进制表示,即文件分配表的每个表目大小为4个字节。FAT 要占用的存储空间总数为:41.2M=4.8M这题关于1.2G 的解答那个“ 1.2M 个盘块号要用31 位二进制表示”这个我怎么都想不明白,上面“540K 个盘块号要用20位二进制表示”我是这样理解540K 介于512k(219 )和1024k( 220)之间,故用 20位二进制表示。8. 存放在某个磁盘上的文件系统采用混合索引分配方式,其 FCB 中共有 6 个地址项,第 03 个地址项为直接地址,第 4 个地址项为一次间接地址,第 5 个地址项为二次间接地址, 。如果每个盘块的大小为 512 字节,若盘块号需要用 4 个字节来描述,而每个盘块最多存放 128 个盘块地址。则:(1)该文件系统允许文件的最大长度是多少?(2)将文件的字节偏移量 500,15000 和 150000 转换为物理块号和块内偏移量。150000/512=292,15000 mod 512=496,即字节偏移量150000对应的逻辑块号为292,可从 FCB 的第11个地址项中得到二次间接地址块的地址;并从二次间接地址块的第0项中获得一个一次间接地址快递地址,再从该一次间接地址块的第112项中获得对应的物理块号,块内偏移为496。(c) 最少需要1次访问磁盘,最多需要4次访问磁盘。