ImageVerifierCode 换一换
格式:DOCX , 页数:20 ,大小:41.83KB ,
资源ID:5027257      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5027257.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(操作系统教程孙仲秀第4版习题及解答.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

操作系统教程孙仲秀第4版习题及解答.docx

1、操作系统教程孙仲秀第4版习题及解答操作系统教程习题及解答 习题一(操作系统概论)二应用题1 有一台计算机,具有1MB内存,操作系统占用200KB,每个进程各占用200KB。如果用户进程等待I/O的时间为80%,若增加1MB内存,则CPU的利用率提高多少 答:设每个进程等待I/O的百分比为P,则n个进程同时等待I/O的概率是,当n个进程同时等待I/O期间CPU是空闲的,故CPU的利用率为1-.由题意可知,除去操作系统,内存还能容纳4个用户进程,由于每个用户进程等待I/O的时间为80%,故:CPU利用率=1-=若再增加1MB内存,系统中可同时运行9个用户进程,此时: CPU利用率=1-=故增加1M

2、B内存使CPU的利用率提高了47%: 87%/59%=147%147%-100%=47%2 一个计算机系统,有一台输入机和一台打印机,现有两道程序投入运行,且程序A先开始做,程序B后开始运行.程序A的运行轨迹为:计算50ms,打印100ms,再计算50 ms,打印100 ms,结束.程序B的运行轨迹为:计算50 ms,输入80 ms,再计算100 ms,结束.试说明(1)两道程序运行时,CPU有无空闲等待若有,在哪段时间内等待为什么会等待(2)程序A,B有无等待CPU的情况若有,指出发生等待的时刻.答:(1)两道程序运行期间,CPU存在空闲等待,时间为100至150ms之间 (2)程序A无等待

3、现象,但程序B有等待.程序B有等待时间段为180ms至200ms间.3.设有三道程序,按A,B,C优先次序运行,其内部计算和I/O操作时间由图给出.A B C =30 ms =60 ms =20 ms =40 ms =30 ms =40 ms =10 ms =10 ms =20 ms试画出按多道运行的时间关系图(忽略调度执行时间).完成三道程序共华多少时间比单道运行节省了多少时间若处理器调度程序每次进行程序转换花时1 ms,试画出各程序状态转换的时间关系图.答:(图略)1)忽略调度执行时间,多道运行方式(抢占式): 抢占式共用去190 ms,单道完成时间需要260 ms,节省70 ms忽略调度

4、执行时间,多道运行方式(非抢占式): 非抢占式共用去180 ms,单道完成时间需要260 ms,节省80 ms2)(略)7. 单道时CPU的利用率为:(19080)/190 多道时CPU的利用率为:(14030)/140=%11. 应时钟中断频率为60HZ,所以时钟频率为:1/6050/3 ms. 在每个时钟周期CPU花2ms执行中断任务。所以CPU用于时钟中断处理的时间比率为:2/(50/3)=12% 习题二(处理器管理)二应用题 1 下列指令中哪些只能在核心态运行(1) 读时钟日期;(2)访管指令;(3)设时钟日期;(4)加载特殊寄存器;(6)改变存储器映象图;(7)启动I/O指令。答:

5、(3),(4),(5),(6),(7).8对某系统进行监测后表明平均每个进程在I/O阻塞之前的运行时间为T。一次进程切换的系统开销时间为S。若采用时间片长度为Q的时间片轮转法,对下列各种情况算出CPU利用率。 1)Q=无穷大 2)QT 3)SQT CPU利用率=T/(T+S) 3)SQ09.按照最短作业优先的算法可以使平均相应时间最短。X的取值不定,按照以下情况讨论:1) x=3 次序为 x , 3 , 5 , 6 , 92) 3x=5 次序为 3 , x , 5 , 6 , 93) 5x=6 次序为 3 , 5 , x , 6 , 94) 6x=9 次序为 3 , 5 , 6 , x , 9

6、5) 9x 次序为 3 , 5 , 6 , 9 , x 11有5个批处理作业A到E均已到达计算中心,其运行时间分别为10,6,2,4和8分钟;各自的优先级分别规定为3,5,2,1和4,这里5为最高级。若不考虑系统切换开销,计算出平均作业周转时间。(1)按FCFS(按A,B,C,D,E);(2)优先级调度算法,(3)时间片轮转法。答:(1) FCFS调度算法 执行次序执行时间等待时间周转时间带权周转时间ABCDE10624801016182210161822301935214作业平均周转时间作业平均带权周转时间T=(10+16+18+22+30)/5=W=(1+9+/5=(2) 优先级调度算法执

7、行次序执行时间等待时间周转时间带权周转时间ABCDE68102406142426614242630113作业平均周转时间作业平均带权周转时间T=(6+14+24+26+30)/5=20W=(1+13+/5=(3) 时间片轮转法 按次序ABCDEABDEABEAEA轮转执行.作业执行时间等待时间周转时间带权周转时间ABCDE1062482016412203022616283343. 5作业平均周转时间作业平均带权周转时间T=(30+22+6+16+28)/5=W=(3+3+4+/5=13请你设计一种先进的计算机体系结构,它使用硬件而不是中断来完成进程切换,则CPU需要哪些信息请描述用硬件完成进程

8、切换的工作过程。答:该计算机有一个专用硬件寄存器,它始终存放指向当前运行进程的PCB的指针.当系统中发生了一个事件,如I/O结束事件,CPU便可把运行进程的上下文保存到专用硬件寄存器指针指向的PCB中保护起来,然后,CPU转向中断向量表,找到设备中断处理程序入口,让专用硬件寄存器指针指向(设备)中断服务例程,于是,便可启动中断服务例程工作.15单道批处理系统中,下列三个作业采用先来先服务调试算法和最高响应比优先算法进行调试,哪一种算法性能较好,请完成下表:作业提交时间运行时间开始时间完成时间周转时间带权周转时间12310:0010:1010:252:001:000:25平均作业周转时间=平均作

9、业带权周转时间W=答: FIFO作业提交时间运行时间开始时间完成时间周转时间带权周转时间12310:0010:1010:252:001:000:2510:0012:0013:0012:0013:0013:2522:503120/120145/60180/25平均作业周转时间=平均作业带权周转时间W=HRN作业提交时间运行时间开始时间完成时间周转时间带权周转时间12310:0010:1010:252:001:000:2510:0012:2512:0012:0013:2512:2523:152120/120195/60120/25平均作业周转时间=平均作业带权周转时间W=可见HRRF比FIFO要好

10、.19有一个具有两道作业的批处理系统,作业调度采用短作业优先的调试算法,进程调度采用优先数为基础的抢占式调度算法,在下表所示的作业序列,作业优先数即为进程优先数,优先数越小优先级越高。 作业名到达时间估计运行时间优先数ABCD10:0010:2010:3010:5040分30分50分20分5346答: 每个作业运行将经过两个阶段:作业调度(SJF算法)和进程调度(优先数抢占式).另外,批处理最多容纳2道作业,更多的作业将在后备队列等待. 作业进入内存时间差运行结束时间ABCD10:0010:2011:1010:5011:1010:5012:0012:20各作业周转时间为:作业A 70, 作业B

11、 30, 作业C 90, 作业D 90.平均作业周转时间为70分钟24.实时任务可调度应满足:35/50+20/100+10/300+x/2501x250(1-28/30)=250*=习题三(并发进程)二应用题1 有三个并发进程:R负责从输入设备读入信息块,M负责对信息块加工处理;P负责打印输出信息块。今提供:1) 一个缓冲区,可放置K个信息块;2) 二个缓冲区,每个可放置K个信息块;试用信号量和P,V操作写出三个进程正确工作的流程。答:1) var B:array0,k-1 of item;sread:semaphore:=k;smanage:semaphore:=0;swrite:sema

12、phore:=0;rptr:integer:=0;mptr:inerger:=0;wptr:inerger:=0;x:itemcobeginprocess reader; beginL1: reader a message into x; P(sread); Brptr:=x; rptr=(rptr +1) mod k; V(smanage); Goto L1;End;process manager;beginL2: P(smanage); x=Bmptr; mptr=(mptr+1) mod k; manager the message in x;Bmptr:=xV(swrite)Goto

13、L2;End;Process writer;BeginL3:P(swrite);x=Bwptr;wptr=(wptr+1) mod k;V(stread);Print the message in x;Goto L3;End;Coend2) var A,B:array0,k-1 of intm;sput1:semaphore:=k; sput2:semaphore:=k; sget1:semaphore:=0;sget2:semaphore:=0;put1:integer:=0;put2:integer:=0;get1:integer:=0;get2:integer:=0;cobeginpro

14、cess reader;beginL1: read a message into x;P(sput1);Aput1=x;Put1:=( put1+1) mod k;V(sget1);Goto L1;End;Process manager;BeginL2:P(sget1);X:=Aget1;Get1:=(get1+1) mod k;V(sput1)Manage the message into x;P(sput2);Bput2:=xPut2:=(put2+1) mod k;V(sget2);Goto L2;End;Process writer;BeginL3:P(sget2);X:=Bget2;

15、Get2:=(get2+1) mod k;V(sput2);Print the message in x;Goto L3;End;coend3.有两个优先级相同的进程P1和P2,各自执行的操作如下,信号量S1和S2初值均为0。试问P1,P2并发执行后,?x,y,z的值各为多少P1: P2: begin begin y:=1; 1 x:=1; 5 y:=y+3; 2 x:=x+5; 6 V(S1); P(S1); z:=y+1; 3 x:=x+y; 7 P(S2); V(S2); y:=z+y; 4 z:=z+x; 8 end. end.1,2,5和6是不相交语句,可以任何次序交错执行,而结果是

16、唯一的。接着无论系统如何调度进程并发执行,当执行到语句7时,可以得到x=10,y=4。按Bernstein条件,语句3的执行结果不受语句7的影响,故语句3执行后得到z=25。最后,语句4和8并发执行,最后结果为:答 语句4先执行 :x=10,y=9,z=15. 语句8先执行 x=10,y=19,z=155.在一个盒子里,混装了数量相等的黑白围棋子。现在用自动分拣系统把黑子,白子分开,设分拣系统有二个进程P1和P2,其中P1拣白子,P2拣黑子。规定每个进程每次拣一子;当一个进程在拣时,不允许另一个进程去拣;当一个进程拣了一子时,必须让另一个进程去拣。试写出两个进程P1和P2能并发正确执行的程序。

17、答:实质上是两个进程的同步问题,设信号量S1 和S2分别表示可拣白子和黑子,不失一般性,若令先拣白子.Var S1,S2:semaphore; S1:=1,S2:=0;Cogegin process P1begin repeat P(S1);拣白子V(S2);Until false;End Process p2Begin Repeat P(S2);拣黑子;V(S1);Until false;Endcoend.17吸烟者问题答:用信号量和P,V操作Var s,s1,s2,s3;semaphore; S:=1;s1=s2=s3=0;Flag1,flag2,flag3: Boolean; Flag1

18、=flag2=flag3=TRUE ; Cobegin Process 供应者 Begin Repeat P(S); 取两样香烟原料放桌上,由flag i标记;flag1/flag2/flag3分别代表烟草,纸、火 If flag2 & flag3 then v(s1) ;、供应纸和火 Else if flag1 & flag3 then v(s2);、供应草和火 Else v(s3); Untile false ; endProcess 吸烟者 1 Begin Repeat P(s1) 取原料,做香烟; (S); 吸香烟;Untile false; Process 吸烟者 2 Begin R

19、epeat P(s2) 取原料,做香烟; (S); 吸香烟;Untile false;Process 吸烟者 3 Begin Repeat P(s3) 取原料,做香烟; (S); 吸香烟;Untile false;Coend27.答:(1)系统处于安全状态,存在安全序列:p0,p3,p4,p1,p2;(2) 不能分配,否则系统会处于不安全状态。 33. ()系统四个进程需要使用的资源数为各台,各台。可见资源数不足。同时各进程申请资源在先,有可能产生死锁发生的四个条件,故系统可能产生死锁。()当三个进程执行完申请资源,开始申请资源时,第四个进程会因没有资源而被阻塞。当三个进程执行完申请资源后,系

20、统还剩个资源。而这三个进程因执行申请第二个资源而全部被阻塞,系统进入死锁。习题四(存储管理)二应用题3一个页式存储管理系统使用FIFO,OPT和LRU页面算法,如果一个作业的页面走向为4,3,2,1,4,3,5,4,3,2,1,5。当分配给该作业的物理块数分别为3和4时,试计算访问过程中发生的缺页中断次数和缺页中断率。答:作业的物理块数为3块时,使用FIFO为9次,9/12=75% 使用LRU为10次,10/12=83% 使用OPT为7次,7/12=58%作业的物理块数为4块时,使用FIFO为10次,10/12=83% 使用LRU为8次,80/12=66% 使用OPT为6次,6/12=50%其

21、中,出现了Belady现象,增加分给作业的内存块数,反使缺页中断率上升.4.在可变分区存储管理下,按地址排列的内存空闲区为:10K,4K,20K,18K,7K,9K,12K,和15K。对于下列的连续存储区的请求:(1)12K,10K,9K。(2)12K,10K,15K,18K试问:使用首次造应算法,最佳造应算法,最差适应算法和下次适应算法,哪个空闲区被使用答:空闲分区如图所示: 分区号分区长1234567810KB4 KB20 KB18 KB7 KB9 KB12 KB15 KB1) 首次造应算法12KB选中分区3,这时分区3还剩选中分区1.恰好分配故应删去分区1. 9KB选中分区4,这时分区4

22、还剩9KB.2) 最佳造应算法 12KB选中分区7, 恰好分配故应删去分区7. 10KB选中分区1.恰好分配故应删去分区1. 9KB选中分区6.恰好分配故应删去分区6.3) 最差适应算法 12KB选中分区3,这时分区3还剩8KB. 10KB选中分区4, 这时分区4还剩8KB. 9KB选中分区8,这时分区8还剩6KB.4) 下次适应算法 12KB选中分区3,这时分区3还剩8KB. 10KB选中分区4, 这时分区4还剩8KB.9KB选中分区6.恰好分配故应删去分区6.(2)原理分区情况同上图1) 首次造应算法12KB选中分区3,这时分区3还剩选中分区1.恰好分配故应删去分区1. 15KB选中分区4

23、,这时分区4还剩3KB.最后无法满足18KB的申请,应该等待.2)最佳造应算法 12KB选中分区7, 恰好分配故应删去分区7. 10KB选中分区1.恰好分配故应删去分区选中分区8.恰好分配故应删去分区8. 18KB选中分区4.恰好分配故应删去分区4.3) 最差适应算法 12KB选中分区3,这时分区3还剩8KB. 10KB选中分区4, 这时分区4还剩8KB. 15KB选中分区8, 恰好分配故应删去分区8. 最后无法满足18KB的申请,应该等待.4) 下次适应算法 12KB选中分区3,这时分区3还剩8KB. 10KB选中分区4, 这时分区4还剩8KB.15KB选中分区8, 恰好分配故应删去分区8.

24、 最后无法满足18KB的申请,应该等待.5,给定内存空闲分区,按地址从小到大为:100K,500K,200K,300K和600K。现有用户进程依次分别为212K,417K,112K和426K,(1)分别用first-fit,best-fit和worst-fit算法将它们装入到内存的哪个分区(2)哪个算法能最有效利用内存答:按题意地址从小到大进行分区如图所示:分区号分区长12345100KB500KB200KB300KB600KB(1)1) first-fit 212KB选中分区2 ,这时分区2还剩288KB. 417KB选中分区5, 这时分区5还剩183KB. 112KB选中分区2 ,这时分区

25、2还剩176KB. 426KB无分区能满足,应该等待.2) best-fit 212KB选中分区4 ,这时分区4还剩88KB. 417KB选中分区2, 这时分区2还剩83KB. 112KB选中分区3 ,这时分区3还剩88KB. 426KB选中分区5 ,这时分区5还剩174KB.3) worst-fit 212KB选中分区5 ,这时分区5还剩388KB. 417KB选中分区2, 这时分区2还剩83KB. 112KB选中分区5 ,这时分区5还剩176KB. 426KB无分区能满足,应该等待.(2)对于该作业序列, best-fit算法能最有效利用内存7内存有3个和4个空闲页框的情况下,页面替换次数

26、为9次和10次,出现了Belady现象。9某计算机有cache,内存,辅存来实现虚拟存储器。如果数据在cache中,访问它需要20ns;如果在内存但不在cache ,需要60ns将其装入缓存,然后才能访问;如果不在内存而在辅存,需要不是12ms将其读入内存,然后,用60 ns再读入cache,然后才能访问。假设cache命中率为,内存命中率为,则数据平均访问时间是多少(ns)答:20*+(60+20)*+(20+60+12000)*=506ns18. 答:t1时刻的工作集为:1,2,3,6,7,8,9 t2时刻的工作集为:3,420答:虚地址0AC5H对应的物理地址为:12C5H。而执行虚地址

27、1AC5H会发现页表中尚未有分配的页框而发生缺页中断,由系统另行分配页框。21答:(1)FIFO 淘汰 page 2(2) LRU 淘汰 page 1(3) 二次机会淘汰 oage 0 习题五5. 对磁盘存在下面五个请求:请求柱面号磁头号扇区号172827253712430535366假如当前磁头位于1号柱面.试分析对这五个请求如何调度,可使磁盘的旋转圈数为最少答:使磁盘的旋转圈数为最少的调度次序为:5,3,2,1和410.答:采用FIFO次序为:100,23,376,205,132,19,61,190,398,29,4,18,40,总柱面数是1596采用SSTF次序为:100,132,190

28、,205,61,40,29,23,19,18,4,376,398总柱面数是 700采用SCAN次序为:100,132,190,205,376,398,61,40,29,23,19,18,4总柱面数是 69215非优化存放,读一块数据需要时间为: 13x6+100+25=203ms因而传输100块的文件的时间为:20300ms优化存放,读一块数据需要时间为: 2x6+100+25=137ms因而传输100块的文件的时间为:13700ms16.磁盘请求以10,22,20,2,40,6,38柱面的次序到达磁盘驱动器,如果磁头当前位于柱面20.若查找移动每个柱面要花6ms.用以下算法计算出查找时间:1)F

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1