操作系统第三版第三章习题复习资料.docx
第三章 处理机调与死锁1 黄兰 10计科3班P114低级调度的主要功能答:(1)保存处理的现场信息。在进程调度进行调度时,首先需要保存当前进程的处理机的现场信息,如程序计数器、多个通用寄存器中的内容等,将它们送入该进程的进程控制块(PCB)中的相应单位。(2)按某种算法选取进程。低级调度程序按某种算法如优先数算法、轮转法等,从就绪队列中选取一个进程,把它的状态改为运行状态,并准备把处理机分配给它。(3)把处理器分配给进程。由分派程序把处理器分配给进程。此时需为选中的静态进程恢复处理机现场,即把选中进程的进程控制块内有关处理机现场的信息装入处理器相应的各个寄存器中,把处理器的控制权交给该进程,让它从取出的断点处开始运行。P1159.何谓静态与动态优先级?确定静态优先级的依据是什么?答:(1)静态优先级定义:静态优先权是在创建进程时确定的,且在进程的整个运行期间保持不变。一般地,优先权是利用某一个整数来表示的,例如,07或0255中的某一整数,又把该整数称为优先数,只是具体用法各异:有的系统用“0”表示优先权,当数值越大时,其优先权越低;而有的系统恰恰相反。(2)动态优先级定义:动态优先权是指在创建进程时所赋予的优先权,是可以随进程的推进或随其等待时间的增加而改变的,以便获得更好的调度性能。(3)确定优先级的依据:进程类型。进程对资源的需要。用户要求。10.试比较FCFS与SPF两种进程调度算法。答:(1)相同点:两种调度算法都是既可用于作业调度,也可用于进程调度。(2)不同点:FCFS调度算法每次调度都是从后备队列中选择一个或是多个最先进入该队列的作业,将他们调入内存,为他们分配资源,创建进程,然后插入到就绪队列中。该算法有利于长作业/进程,不利于短作业/进程。SPF调度算法每次调度都是从后备队列中选择一个或若干个估计运行时间最短的作业,将它们调入内存中运行。该算法有利于短作业/进程,不利于长作业/进程。18.何谓死锁?产生死锁的原因与必要条件是什么?答:(1)所谓死锁,是指多个进程在运行过程中因争夺资源而造成的一种僵局,当进程处于这样僵局状态时,若无外力作用,它们都将无法再向前推进。(2) b.21.在银行家算法的例子中,如果P0发出的请求向量由Request(0,2,0)改为Request(0,1,0),请问系统可否将资源分配给它?答:P0请求资源:P0发出请求向量Request(0,1,0),系统按银行家算法进行检查: Request0(0,1,0)Need0(7,4,3); Request0(0,1,0)Available(2,3,0); 系统先假定可为P0分配资源,并修改Available,Allocation与Need向量,由此形成的资源变化情况如下图所示:WorkNeedAllocationWork+AllocationFinishABCABCABCABCtrueP1220020302522trueP3522011211733trueP4733430002735trueP27356003021037trueP010377330201057.true由所进行的安全性检查得知,可以找到一个安全序列P1,P3,P4,P2,P0。因此,系统是安全的,可以立即将P0所申请的资源分给它。22.在银行家算法中,若出现下述资源分配情况:ProcessAllocationNeedAvailableP0003200121622P110001750P213542356P303320652P400140656试问 (1) 该状态是否安全?(2) 若进程P2提出请求Request(1,2,2,2)后,系统能否将资源分配给它?答:(1)在该时刻下,利用安全性算法对该时刻的资源分配情况进行分析,如下图所示:WorkNeedAllocationWork+AllocationFinishP01622001200321654trueP31654065203321986trueP419860656001419910trueP1199101750100029910trueP229910235613543121414true由上图可知,存在一个安全序列P0,P3,P4,P1,P2,所以该状态是安全的。(2)P2请求资源:P2发出请求向量(1,2,2,2),系统按银行家算法进行检查:Request(1,2,2,2)Need(2,3,5,6)Request(1,2,2,2)Available(1,6,2,2) 系统先假定可为P2分配资源,并修改相关数据。如图所示:AllocationNeedAvailableP0003200120400P110001750P225761134P303320652P400140656进行安全检查:可用资源Available(0,4,0,0)已经不能满足任何进程的需要,故系统进入不安全状态,此时系统不分配资源。