white;background-color:
#886800'>它为何能有这些优点?
答:
1)提高了系统的可扩展性
2)增强了系统的可靠性
3)可移植性
4)提供了对分布式系统的支持
5)融入了面向对象技术
第二章
1.什么是前趋图?
为什么要引入前趋图?
答:
前趋图(PrecedenceGraph)是一个有向无循环图,记为DAG(DirectedAcyclic
Graph),用于描述进程之间执行的前后关系。
2.画出下面四条诧句的前趋图:
S1=a:
=x+y;S2=b:
=z+1;S3=c:
=a–b;S4=w:
=c+1;
答:
其前趋图为:
3.什么程序并収执行会产生间断性特征?
答:
程序在并发执行时,由于它们共享系统资源,为完成同一项任务需要相互合作,致使这些并发执行的进程之间,形成了相互制约关系,从而使得进程在执行期间出现间断性。
4.程序并収执行时为什么会失去封闭性和可再现性?
答:
程序并发执行时,多个程序共享系统中的各种资源,因而这些资源的状态由多个程序改变,致使程序运行失去了封闭性,也会导致其失去可再现性。
5.在操作系统中为什么要引入迚程概念?
它会产生什么样的影响?
答:
为了使程序在多道程序环境下能并发执行,并对并发执行的程序加以控制和描述,在操作系统中引入了进程概念。
影响:
使程序的并发执行得以实行。
6.试从劢态性,并収性和独立性上比较迚程和程序?
答:
(1)动态性是进程最基本的特性,表现为由创建而产生,由调度而执行,因得不到资源而暂停执行,由撤销而消亡。
进程有一定的生命期,而程序只是一组有序的指令集合,是静态实体。
(2)并发性是进程的重要特征,同时也是OS的重要特征。
引入进程的目的正是为了使其程序能和其它进程的程序并发执行,而程序是不能并发执行的。
(3)独立性是指进程实体是一个能独立运行的基本单位,也是系统中独立获得资源和独立调度的基本单位。
对于未建立任何进程的程序,不能作为独立单位参加运行。
7.试说明PCB的作用,为什么说PCB是迚程存在的惟一标志?
答:
PCB是进程实体的一部分,是操作系统中最重要的记录型数据结构。
作用是使一个在多道程序环境下不能独立运行的程序,成为一个能独立运行的基本单位,成为能与其它进程并发执行的进程。
OS是根据PCB对并发执行的进程进行控制和管理的。
8.试说明迚程在三个基本状态之间转换的典型原因。
答:
(1)就绪状态→执行状态:
进程分配到CPU资源
(2)执行状态→就绪状态:
时间片用完
(3)执行状态→阻塞状态:
I/O请求
(4)阻塞状态→就绪状态:
I/O完成
9.为什么要引入挂起状态?
该状态有哪些性质?
答:
引入挂起状态处于五种不同的需要:
终端用户需要,父进程需要,操作系统需要,对换需要和负荷调节需要。
处于挂起状态的进程不能接收处理机调度。
10.在迚行迚程切换时,所要保存的处理机状态信息有哪些?
答:
进行进程切换时,所要保存的处理机状态信息有:
(1)进程当前暂存信息
(2)下一指令地址信息
(3)进程状态信息
(4)过程和系统调用参数及调用地址信息。
11.试说明引起迚程创建的主要事件。
答:
引起进程创建的主要事件有:
用户登录、作业调度、提供服务、应用请求。
12.试说明引起迚程被撤销的主要事件。
答:
引起进程被撤销的主要事件有:
正常结束、异常结束(越界错误、保护错、非法指令、特权指令错、运行超时、等待超时、算术运算错、I/O故障)、外界干预(操作员或操作系统干预、父进程请求、父进程终止)。
13.在创建一个迚程时所要完成的主要工作是什么?
答:
(1)OS发现请求创建新进程事件后,调用进程创建原语Creat();
(2)申请空白PCB;
(3)为新进程分配资源;
(4)初始化进程控制块;
(5)将新进程插入就绪队列.
14.在撤销一个迚程时所要完成的主要工作是什么?
答:
(1)根据被终止进程标识符,从PCB集中检索出进程PCB,读出该进程状态。
(2)若被终止进程处于执行状态,立即终止该进程的执行,臵调度标志真,指示该进程被
终止后重新调度。
(3)若该进程还有子进程,应将所有子孙进程终止,以防它们成为不可控进程。
(4)将被终止进程拥有的全部资源,归还给父进程,或归还给系统。
(5)将被终止进程PCB从所在队列或列表中移出,等待其它程序搜集信息。
15.试说明引起迚程阻塞戒被唤醒的主要事件是什么?
答:
a.请求系统服务;b.启动某种操作;c.新数据尚未到达;d.无新工作可做.
16.迚程在运行时存在哪两种形式的制约?
并丼例说明之。
答:
(1)间接相互制约关系。
举例:
有两进程A和B,如果A提出打印请求,系统已把唯一的
一台打印机分配给了进程B,则进程A只能阻塞;一旦B释放打印机,A才由阻塞改为就
绪。
(2)直接相互制约关系。
举例:
有输入进程A通过单缓冲向进程B提供数据。
当缓冲空时,
计算进程因不能获得所需数据而阻塞,当进程A把数据输入缓冲区后,便唤醒进程B;反
之,当缓冲区已满时,进程A因没有缓冲区放数据而阻塞,进程B将缓冲区数据取走后便唤醒A。
17.为什么迚程在迚入临界区之前应先执行“迚入区”代码?
而在退出前又要执行“退出区”代码?
答:
为了实现多个进程对临界资源的互斥访问,必须在临界区前面增加一段用于检查欲访问的临界资源是否正被访问的代码,如果未被访问,该进程便可进入临界区对资源进行访问,并设臵正被访问标志,如果正被访问,则本进程不能进入临界区,实现这一功能的代码为"在退出临界区后,必须执行"退出区"代码,用于恢复未被访问标志,使其它进程能再访问此临界资源。
18.同步机构应遵循哪些基本准则?
为什么?
答:
同步机构应遵循的基本准则是:
空闲让进、忙则等待、有限等待、让权等待原因:
为实现进程互斥进入自己的临界区。
19.试从物理概念上说明记录型信号量wait和signal。
答:
wait(S):
当S.value>0时,表示目前系统中这类资源还有可用的。
执行一次wait操作,意味着进程请求一个单位的该类资源,使系统中可供分配的该类资源减少一个,因此描述为S.value:
=S.value-1;当S.value<0时,表示该类资源已分配完毕,进程应调用block原语自我阻塞,放弃处理机,并插入到信号量链表S.L中。
signal(S):
执行一次signal操作,意味着释放一个单位的可用资源,使系统中可供分配的该类资源数增加一个,故执行S.value:
=S.value+1操作。
若加1后S.value≤0,则表示在该信号量链表中,仍有等待该资源的进程被阻塞,因此应调用wakeup原语,将S.L链表中的第一个等待进程唤醒。
20.你认为整型信号量机制是否完全遵循了同步机构的四条准则?
答:
整型信号量机制不完全遵循同步机制的四条准则,它不满足“让权等待”准则。
21.如何利用信号量机制来实现多个迚程对临界资源的互斥访问?
并丼例说明之。
答:
为使多个进程互斥访问某临界资源,只需为该资源设臵一互斥信号量mutex,并设其
初值为1,然后将各进程访问该资源的临界区CS臵于wait(mutex)和signal(mutex)操作
之间即可。
这样,每个欲访问该临界资源的进程在进入临界区之前,都要先对mutex执行
wait操作,若该资源此刻未被访问,本次wait操作必然成功,进程便可进入自己的临界区,
这时若再有其他进程也欲进入自己的临界区,此时由于对mutex执行wait操作定会失败,
因而该进程阻塞,从而保证了该临界资源能被互斥访问。
当访问临界资源的进程退出临界区
后,应对mutex执行signal操作,释放该临界资源。
利用信号量实现进程互斥的进程描述
如下:
Varmutex:
semaphore:
=1;
begin
parbegin
process1:
begin
repeat
wait(mutex);
criticalsection
signal(mutex);
remainderseetion
untilfalse;
end
process2:
begin
repeat
wait(mutex);
criticalsection
signal(mutex);
remaindersection
untilfalse;
end
parend
22.试写出相应的程序来描述图2-17所示的前驱图。
答:
(a)Vara,b,c,d,e,f,g,h;semaphore:
=0,0,0,0,0,0,0,0;
begin
parbegin
beginS1;signal(a);signal(b);end;
beginwait(a);S2;signal(c);signal(d);end;
beginwait(b);S3;signal(e);end;
beginwait(c);S4;signal(f);end;
beginwait(d);S5;signal(g);end;
beginwait(e);S6;signal(h);end;
beginwait(f);wait(g);wait(h);S7;end;
parend
end
(b)Vara,b,c,d,e,f,g,h,i,j;semaphore:
=0,0,0,0,0,0,0,0,0,0;
begin
parbegin
beginS1;signal(a);signal(b);end;
beginwait(a);S2;signal(c);signal(d);end;
beginwait(b);S3;signal(e);signal(f);end;
beginwait(c);S4;signal(g);end;
beginwait(d);S5;signal(h);end;
beginwait(e);S6;signal(i);end;
beginwait(f);S7;signal(j);end;
beginwait(g);wait(h);wait(i);wait(j);S8;end;
parend
end
23.在生产者消费者问题中,如果缺少了signal(full)戒signal(empty),对执行结果有何影
响?
答:
如果缺少signal(full),那么表明从第一个生产者进程开始就没有改变信号量full值,即使缓冲池产品已满,但full值还是0,这样消费者进程执行wait(full)时认为缓冲池是空而取不到产品,消费者进程一直处于等待状态。
如果缺少signal(empty),在生产者进程向n个缓冲区投满产品后消费者进程才开始从中取产品,这时empty=0,full=n,那么每当消费者进程取走一个产品empty值并不改变,直到缓冲池取空了,empty值也是0,即使目前缓冲池有n个空缓冲区,生产者进程要想再往缓冲池中投放产品也会因为申请不到空缓冲区被阻塞。
24.在生产消费者问题中,如果将两个wait操作卲wait(full)和wait(mutex)互换位置,戒者将signal(mutex)不signal(full)互换位置,结果如何?
答:
将wait(full)和wait(mutex)互换位臵后,可能引起死锁。
考虑系统中缓冲区全满时,若一生产者进程先执行了wait(mutex)操作并获得成功,则当再执行wait(empty)操作时,它将因失败而进入阻塞状态,它期待消费者进程执行signal(empty)来唤醒自己,在此之前,它不可能执行signal(mutex)操作,从而使试图通过执行wait(mutex)操作而进入自己的临界区的其他生产者和所有消费者进程全部进入阻塞状态,这样容易引起系统死锁。
若signal(mutex)和signal(full)互换位臵后只是影响进程对临界资源的释放次序,而不会引起系统死锁,因此可以互换位臵。
25.我们在为某一临界资源设置一把锁W,当W=1时表示关锁,当W=0时表示锁已打开。
试写出开锁和关锁的原诧,并利用他们实现互斥。
答:
整型信号量:
lock(W):
whileW=1dono-op
W:
=1;
unlock(W):
W:
=0;
记录型信号量:
lock(W):
W:
=W+1;
if(W>1)thenblock(W,L)
unlock(W):
W:
=W-1;
if(W>0)thenwakeup(W,L)
例子:
VarW:
semaphore:
=0;
begin
repeat
lock(W);
criticalsection
unlock(W);
remaindersection
untilfalse;
end
26.试修改下面生产者-消费者问题解法中的错诨:
答:
producer:
begin
repeat
…
produceraniteminnextp;
wait(mutex);
wait(full);/*应为wait(empty),而且还应该在wait(mutex)的前面*/
buffer(in):
=nextp;
/*缓冲池数组游标应前移:
in:
=(in+1)modn;*/
signal(mutex);
/*signal(full);*/
untilfalse;
end
consumer:
begin
repeat
wait(mutex);
wait(empty);/*应为wait(full),而且还应该在wait(mutex)的前面*/
nextc:
=buffer(out);
out:
=out+1;/*考虑循环,应改为:
out:
=(out+1)modn;*/
signal(mutex);/*signal(empty);*/
consumeriteminnextc;
untilf