操作系统课后习题答案2知识分享 下载本文

A.程序员的命令 B.系统服务

C.等待下一个时间片到来 D.“合作”进程的唤醒

21. 在WINDOWS NT 中( )可以处于就绪状态。 A. 进程 B. 线程 C. 程序 D. 作业

22. 只作用于一个进程一次的原语是____________. A.创立 B.解挂 C.阻塞 D.挂起

23. 在UNIX系统中,处于( )状态的进程最容易被执行。

A.辅存睡眠 B.内存睡眠 C.内存就绪 D. 辅存就绪 24. 从执行状态挂起的进程解除挂起时进入( )状态。 A.就绪 B.执行 C.阻塞 D.挂起 25. 一个进程执行过程中不能可能对应( )。

A.一个PCB B.一个JCB C.多个PCB D.一个程序 2.3.2 选择所有正确的答案

1. 在下列进程的四个特征中,最基本的特征是( )。 A.并发性 B. 动态性 C. 独立性 D. 异步性 2. 下面会引起进程创建的事件是( )。

A.用户登录 B. 设备中断 C. 作业调度 D. 执行系统调用 3. 下面是关于线程的叙述,其中正确的是( )。

A.线程自己拥有一点资源,但它可以使用所属进程的资源。

B.由于同一进程中的多个线程具有相同的地址空间,所以它们间的同步和通信也易于实现。 C.进程创建与线程创建的时空开销不相同。 D.进程切换与线程切换的时空开销相同。 4. 在下面的叙述中,不正确的是( )。

A.同一进程内的线程可并发执行,不同进程的线程只能串行执行。 B.同一进程内的线程只能串行执行,不同进程的线程可并发执行。 C.同一进程或不同进程内的线程都只能串行执行。 D.同一进程或不同进程内的线程都可以并发执行。

5. 线程是操作系统的概念,已具有线程管理的操作系统有( )。 A.Windows3.2 B. OS/2 C. Windows NT D. Mach

6. 下面属于进程基本状态的是( )。 A.就绪 B. 运行 C. 后备 D. 阻塞 7. 下列各项工作步骤,( )是创建进程所必须的步骤。 A.建立一个PCB

B.由CPU调度程序为进程调度CPU C.为进程分配内存等必要资源 D.将PCB接入进程就绪队列

8. 关于进程的正确说法是( )。

A.进程就是程序,或者说,进程是程序的另一种叫法

B.一个被创建了的进程,在它被消灭之前,大多数时刻处于进程的三种基本状态之一。 C.多个不同的进程可以包含相同的程序

D.一个处于等待队列中的进程,即使进入其它状态,仍然放在等待队列中。 9. 在( )时,可能挂起某进程。

A.进程出现死锁 B.进程的数目太少

C.进程数目太多 D.进程出现故障

10. 多道程序系统进程从执行状态转换到就绪状态的原因是( )。 A.时间片完 B.等待其它进程的执行结果 C.等待I/O D.有更高优先级的进程到来 2.3.3 判断正误,错误的简要说明理由

1. 有了线程之后,程序只能以线程的身份运行。 2. 线程的切换会引起进程的切换。 3. 多个线程可以对应同一段程序。 4. 系统内可以有无父进程的进程。

5. 线程所对应的程序肯定比进程所对应的程序短。 6. 进程从CPU退下时,将“现场”保存在系统栈内。

7. 在多道程序系统,进程需要等待某种事件的发生时,进程一定进入阻塞状态。 8. 进程上下文是进程执行活动全过程的静态描述。 9. 并发是并行的不同表述,其原理相同。

10. 进程是基于多道程序技术而提出的,其基本的特征是动态性;进程的执行是在多个状态间多次转换的过程,但只有处于就绪和执行状态的进程位于内存。 11. 操作系统对进程的管理和控制主要是通过控制原语实现的。 12. 原语的执行是屏蔽中断的。

13. 一般情况下,分时系统中处于就绪状态的进程最多。 14. 系统中进程的数目越多,CPU的利用率越高.

15. 多道程序的执行失去了封闭性和再现性,因此多道程序系统不需要封闭性和再现性。 16. 一个多道程序可能具备封闭性和再现性。 17. 单道程序不具备封闭性和再现性。 2.3.4 简答题

1. Windows这样的多任务系统与Unix这样的多进程系统在调度上有何不同? 2. 进程和线程的主要区别是什么? 3. 程序的并发执行为什么会有间断性?

4. 进程能自己将自己唤醒吗?进程能自己将自己撤消吗? 5. 什么是原语?原语的主要特点是什么?

6. 程序并发执行与顺序执行时相比产生哪些新特征? 7. 程序并发执行的主要特性是什么?

8. 一个因等待I/O操作结束而入阻塞状态的进程,何时被唤醒? 9. 在什么情况下,可以一次唤醒一个进程和一次唤醒多个进程? 10. 进程的就绪状态和阻塞状态的有何不同?

11. 程序的并行执行将导致运行结果失去封闭性,这对所有的程序都成立吗? 12. 父进程创建子进程之后,父子进程之间的关系是什么? 2.3.5 解答题

1. 什么是线程?进程和线程是什么关系? 2. 简述引进线程的好处。

3. 当系统内所有的进程都进入睡眠之后,系统还有可能复活吗? 4. 当一个进程的父进程被撤消时,该进程是撤消好还是不撤消好? 5. 进程的挂起操作和入睡操作有何异同?

6. 简述进程为什么不能从就绪状态直接变成阻塞(睡眠)状态?

7. 进程的三个基本的转换如下图所示,图中1、2、3、4分别代表某种类型状态变迁,请分

别回答:

什么事件引起各状态之间的变迁?

统中常常由于某一进程的状态变迁引起另一进程也产生状态变迁,试判断变迁3——1、2——1、3——2、4——1、3——4,如果有的话,将发生什么因果变迁 在什么情况下,如果有的话,上述变迁将不引起其它变迁? 2.4 习题解答要点

2.4.1 选择最合适的答案

1.A 2.B 3.D 4.B 5.A 6.C 7.D 8.D 9.A 10.B 11.A 12.C 13.B 14.C 15.A 16.B 17.C 18.D 19.B 20.D 21.A 22.A 23.C 24.A 25.C 2.4.2 选择所有正确的答案

1. AB 2. ACD 3. ABC 4.ABC 5.BCD 6.ABD 7. ACD 8. BC 9. ACD 10.AD

2.4.3 判断正误,简要说明理由 1. 正确 错误

属于同一进程的多个线程之间的切换不会引起进程的切换,只有属于不同进程的线程之间的切换才会引起进程的切换。 3. 正确 4. 正确 5. 错误

不一定,若进程只有一个线程的话。 6. 错误

应该保存在PCB中,但有的系统也有例外。 7. 错误

进程也可以循环等待。 8. 错误

进程是进程实体的执行过程,具有动态性。 9. 错误

若干个事件在同一时刻发生成为并行;若干个事件在同一时间间隔内发生成为并发。并行是并发的特例,并发是并行的拓展。 10. 错误

基本特征还有并发性、异步性、独立性等; 进程在新、终止两状态中只经过一次; 进程都在内存。 11. 正确 12. 正确 13. 正确 14. 错误

进程容易产生资源竞争而处于阻塞或死锁状态 15. 错误

需要,否则程序没有稳定性和可靠性而言,用户也无法使用。 16. 正确

通过程序员的设计可以达到。 17. 错误

这是单道程序的固有属性。 2.4.4 简答题

1. 从调度上讲,在Windows这样的多任务系统中,当前执行哪个任务是由用户决定的,是用户可控的;而在Unix这样的多进程系统中,当前运行哪个进程是由内部的调度算法决定的,是对用户透明的,用户是不可直接控制的。

2. 在有进程和线程的系统中,进程是系统资源分配的独立单位,而线程是可调度运行的独立单位。

3. 并发执行是指系统内有多道程序在宏观上“同时”执行,但系统内往往只有一台处理机(CPU),因此只能分时地为多个程序服务。就一道程序而言,往往不是一次能够运行完成,而是以“走走停停”的方式完成其运行,这就是并发系统内程序执行的间断性。

4. 唤醒进程和撤消进程都是要通过在CPU上运行程序来实现的。一个进程入睡了,它就不可能被调度到CPU上运行;一个进程在撤消前必须先进入终止状态,而处于终止状态的进程不可能被调度到CPU上运行。因此,进程被唤醒、被撤消都不能由自己来完成,只能由别的进程实现。

5. 原语是指由若干条机器指令构成的,并用以完成特定功能的一段程序。这段程序在执行期间是不可分割的。其主要特点是不可分割性。 6. 可分割性、失去封闭性、失去可再现性。

7. 并发程序间具有相互制约的关系,程序并发执行失去了程序的封闭性和再现性,程序和机器执行程序的活动不再一一对应。

8. 是在别的进程执行相应的I/O中断处理程序时唤醒的。

9. 在I/O中断处理程序中,当唤醒进程时,只唤醒等待该I/O结束的那一个进程;当一个进程释放一个系统资源(如I/O缓存)时,将要唤醒所有因等待使用该资源而进入阻塞状态的进程。

10. 阻塞状态的进程还不具备执行的条件,即使放到处理机上也不能执行;就绪状态的进程具备了执行的所有条件,放到处理机上就能执行。

11. 并不是所有程序的并行执行都会导致运行结果失去封闭性。例如,当程序中都使用内部变量,不可能被外部程序访问时,程序的运行不会受到外部环境的影响。

12. 一个进程创建子进程之后,创建进程与产生的进程之间的关系是父子关系,分别成为父进程和子进程。子进程一经产生就与父进程并发执行,子进程共享父进程的正文段和已经打开的文件。 2.4.5 解答题

1. 线程可定义为进程内的一个执行单位,或者定义为进程内的一个可调度实体。 在具有多线程机制的操作系统中,处理机调度的基本单位不是进程而是线程。一个进程可以有多个线程,而且至少有一个可执行线程。 进程和线程的关系是:

线程是进程的一个组成部分;

进程的多个线程都在进程的地址空间活动;

资源是分给进程的,而不是分给线程的,线程在执行中需要资源时,系统从进程的资源配额中扣除并分配给它;

处理机调度的基本单位是线程,线程之间竞争处理机,真正在处理机上运行的是线程; 线程在执行过程中,需要同步。 2. 引进线程的好处为: