1、 1 第 2章 第 1 章 一、填空 1计算机由 硬件 系统和 软件 系统两个部分组成,它们构成了一个完整的计算机系统。 2按功能划分,软件可分为 系统 软件和 应用 软件两种。 3操作系统是在 裸机 上加载的第一层软件,是对计算机硬件系统功能的 首次 扩充。 4操作系统的基本功能是 处理机(包含作业) 管理、 存储 管理、 设备 管理和 文件 管理。 5在分时和批处理系统结合的操作系统中引入“前台”和“后台”作业的概念,其目的是 改善系统功能,提高处理能力 。 6分时系统的主要特征为 多路性 、 交互性 、 独立性 和 及时性 。 7实时系统与分时以及批处理系统的主要区别是 高及时性 和 高
2、可靠性 。 8若一个操作系统具有很强的交互性,可同时供多个用户使用,则是 分时 操作系统。 9如果一个操作系统在用户提交作业后,不提供交互能力,只追求计算机资源的利用率、大吞吐量和作业流程的自动化,则属于 批处理 操作系统。 10采用多道程序设计技术,能充分发挥 CPU 和 外部设备 并行工作的能 力。 二、选择 1操作系统是一种 B 。 A通用软件 B系统软件 C应用软件 D软件包 2操作系统是对 C 进行管理的软件。 A 系统软件 B系统硬件 C计算机资源 D应用程序 3操作系统中采用多道程序设计技术,以提高 CPU 和外部设备的 A 。 A利用率 B可靠性 C稳定性 D兼容性 4计算机系
3、统中配置操作系统的目的是提高计算机的 B 和方便用户使用。 A速度 B利用率 C灵活性 D兼容性 5 C 操作系统允许多个用户在其终端上同时交互地使用计算机。 A批处理 B实时 C分时 D多道批处理 6如果分时系统的时间片一定,那么 D ,响应时间越长。 A用户数越少 B内存越少 C内存越多 D用户数越多 三、问答 1什么是“多道程序设计”技术?它对操作系统的形成起到什么作用? 答: 所谓“多道程序设计”技术,即是通过软件的手段,允许在计算机内存中同时存放几道相互独立的作业程序,让它们对系统中的资源进行“共享”和“竞争”,以使系统中的各种资源尽可能地满负荷工作,从而提高整个计算机 系统的使用效
4、率。基于这种考虑,计算机科学家开始把 CPU、存储器、外部设备以及各种软件都视为计算机系统的“资源”,并逐步设计出一种软件来管理这些资源,不仅使它们能够得到合理地使用,而且还要高效地使用。具有这种功能的软件就是“操作系统”。所以,“多道程序设计”的出现,加快了操作系统的诞生。 2怎样理解“虚拟机”的概念? 答: 拿操作系统来说,它是在裸机上加载的第一层软件,是对计算机硬件系统功能的首操作系统习题解答 2 次扩充。从用户的角度看,计算机配置了操作系统后,由于操作系统隐蔽了硬件的复杂细节,用户会感到机器使用起来更方便、容易 了。这样,通过操作系统的作用使展现在用户面前的是一台功能经过扩展了的机器。
5、这台“机器”不是硬件搭建成的,现实生活中并不存在具有这种功能的真实机器,它只是用户的一种感觉而已。所以,就把这样的机器称为“虚拟机”。 3对于分时系统,怎样理解“ 从宏观上看,多个用户同时工作,共享系统的资源;从微观上看,各终端程序是轮流运行一个时间片 ”? 答: 在分时系统中,系统把 CPU 时间划分成许多时间片,每个终端用户可以使用由一个时间片规定的 CPU 时间,多个用户终端就轮流地使用 CPU。这样的效果是每个终端都开始了自己的工作,得到了及时的响应。也就是说,“ 从宏观上看,多个用户同时工作,共享系统的资源” 。但实际上, CPU 在每一时刻只为一个终端服务,即“ 从微观上看,各终端
6、程序是轮流运行一个时间片” 。 操作系统习题解答 3 第 3章 一、填空 1进程在执行过程中有 3 种基本状态,它们是 运行 态、 就绪 态和 阻塞 态。 2系统中一个进程由 程序 、 数据集合 和 进程控制块( PCB) 三部分组成。 3在多道程序设计系统中,进程是一个 动 态概念,程序是一个 静 态概念。 4在一个单 CPU 系统中,若有 5 个用户进程。假设当前系统为用户态,则处于就 绪状态的用户进程最多有 4 个,最少有 0 个。 注意,题目里给出的是假设当前系统为用户态,这表明现在有一个进程处于运行状态,因此最多有 4 个进程处于就绪态。也可能除一个在运行外,其他 4 个都处于阻塞。
7、这时,处于就绪的进程一个也没有。 5总的来说,进程调度有两种方式,即 不可剥夺 方式和 剥夺 方式。 6进程调度程序具体负责 中央处理机( CPU) 的分配。 7为了使系统的各种资源得到均衡使用,进行作业调度时,应该注意 CPU 忙碌 作业和 I/O 忙碌 作业的搭配。 8所谓系统调用,就是用户程序要调用 操作系统 提供的一些子功能。 9 作业被系统接纳后到运行完毕,一般还需要经历 后备 、 运行 和 完成 三个阶段。 10假定一个系统中的所有作业同时到达,那么使作业平均周转时间为最小的作业调度算法是 短作业优先 调度算法。 操作系统习题解答 4 二、选择 1在进程管理中,当 C 时,进程从阻
8、塞状态变为就绪状态。 A进程被调度程序选中 B进程等待某一事件发生 C等待的事件出现 D时间片到 2在分时系统中,一个进程用完给它的时间片后,其状态变为 A 。 A就绪 B等待 C运行 D由用户设定 3下面对进程的描述中,错误的是 D 。 A进程是动态的概念 B进程的执行需要 CPU C进程具有生命周期 D进程是指令的集合 4操作系统通过 B 对进程进行管理。 A JCB B PCB C DCT D FCB 5一个进程被唤醒,意味着该进程 D 。 A重新占有 CPU B优先级变为最大 C移至等待队列之首 D变为就绪状态 6由各作业 JCB 形成的队列称为 C 。 A就绪作业队列 B阻塞作业队列
9、 C后备作业队列 D运行作业队列 7既考虑作业等待时间,又考虑作业执行时间的作业调度算法是 A 。 A响应比高者优先 B短作业优先 C优先级调度 D先来先服务 8作业调度程序从处于 D 状态的队列中选取适当的作业投入运行。 A就绪 B提交 C等待 D后备 9 A 是指从作业提交系统到作业完成的时间间隔。 A周转时间 B响应时间 C等待时间 D运行时间 10计算机系统在执行 C 时,会自动从目态变换到管态。 A P 操作 B V 操作 C系统调用 D I/O 指令 三、问答 1在多道程序设计系统中,如何理解“内存中的多个程序的执行过程交织在一起,大家都在走走停停”这样一个现象? 答: 在多道程序
10、设计系统中,内存中存放多个程序,它们以交替的方式使用 CPU。因此,从宏观上看,这些程序都开始了自己的工作。但由于 CPU 只有一个,在任何时刻 CPU只能执行一个进程程序。所以这些进程程序的执行过程是交织在一起的。也就是说,从微观上看,每一个进程一会儿在向前走,一会儿又停步不前,处于一种“走走停停”的状态之中。 2什么是“原语”、“特权指令”、 “系统调用命令”和“访管指令”?它们之间有无一定的联系? 答: 特权指令和访管指令都是 CPU 指令系统中的指令,只是前者是一些只能在管态下执 行的指令,后者是一条只能在目态下执行的指令。原语和系统调用命令都是操作系统中的功能程序,只是前者执行时不能
11、被其他程序所打断,后者没有这个要求。操作系统中有些系统调用命令是以原语的形式出现的,例如创建进程就是一条原语式的系统调用命令。但并不是所有系统调用命令都是原语。因为如果那样的话,整个系统的并发性就不可能得操作系统习题解答 5 到充分地发挥。 3操作系统是如何处理源程序中出现的系统调用命令的 ? 答: 编译程序总是把源程序中的系统调用命令改写成为一条访管指令和相应的参数。这样在程序实际被执行时,就通过访管指令进入操作系统,达到调用操作系统功能子程序的目的。 4系统调用与一般的过程调用有什么区别? 答: 系统调用是指在用户程序中调用操作系统提供的功能子程序;一般的过程调用是指在一个程序中调用另一个
12、程序。因此它们之间有如下三点区别。 ( 1) 一般的过程调用,调用者与被调用者都运行在相同的 CPU 状态,即或都处于目态(用 户程序调用用户程序),或都处于管态(系统程序调用系统程序);但发生系统调用时,发出调用命 令的调用者运行在目态,而被调用的对象则运行在管态,即调用者与被调用者运行在不同的 CPU 状态。 ( 2)一般的过程调用,是直接通过转移指令转向被调用的程序;但发生系统调用时,只能通过访管指令提供的一个统一的入口,由目态进入管态,经分析后,才转向相应的操作系统命令处理程序。 ( 3)一般的过程调用,在被调用者执行完后,就径直返回断点继续执行;但系统调用可能会导致进程状态的变化,从
13、而引起系统重新分配处理机。因此,系统调用处理结束后,不一定是返回调用者断点处继续执行。 5试述创建进程原语的主要功能。 答: 创建进程原语 的主要功能有以下三项。 ( 1)为新建进程申请一个 PCB。 ( 2)将创建者(即父进程)提供的新建进程的信息填入 PCB 中。 ( 3)将新建进程设置为就绪状态,并按照所采用的调度算法,把 PCB 排入就绪队列中。 6处于阻塞状态的一个进程,它所等待的事件发生时,就把它的状态由阻塞改变为就绪,让它到就绪队列里排队,为什么不直接将它投入运行呢? 答: 只要是涉及管理,就应该有管理的规则,没有规则就不成方圆。如果处于阻塞状态的一个进程,在它所等待的事件发生时
14、就径直将它投入运行(也就是把 CPU 从当前运行进程的手中抢夺过来),那么系统就无法控制对 CPU 这种资源的管理和使用,进而也就失去了设置操作系统的作用。所以,阻塞状态的进程在它所等待的事件发生时,必须先进入就绪队列,然后再去考虑它使用 CPU 的问题。 7作业调度与进程调度有什么区别? 答: 作业调度和进程调度(即 CPU 调度)都涉及到 CPU 的分配。但作业调度只是选择参加 CPU 竞争的作业,它并不具体分配 CPU。而进程调度是在作业调度完成选择后的基础上,把 CPU 真正分配给某一个具体的进程使用。 8系统中的各种进程队列都是由进程的 PCB 链接而成的。当一 个进程的状态从阻塞变
15、为就绪状态时,它的 PCB 从哪个队列移到哪个队列?它所对应的程序也要跟着移来移去吗?为什么? 答: 当一个进程的状态从阻塞变为就绪时,它的 PCB 就从原先在的阻塞队列移到就绪队列里。在把进程的 PCB 从这个队列移到另一个队列时,只是移动进程的 PCB,进程所对应的程序是不动的。这是因为在进程的 PCB 里,总是记录有它的程序的断点信息。知道了断点的信息,就能够知道程序当前应该从哪里开始往下执行了。这正是保护现场所起的作用。 9为什么说响应比高者优先作业调度算法是对先来先服务以及短作业优先这两种调度算 法的折中? 操作系统习题解答 6 答: 先来先服务的作业调度算法,重点考虑的是作业在后备
16、作业队列里的等待时间,因此对短作业不利;短作业优先的作业调度算法,重点考虑的是作业所需的 CPU 时间(当然,这个时间是用户自己估计的),因此对长作业不利。“响应比高者优先”作业调度算法,总是在需要调度时,考虑作业已经等待的时间和所需运行时间之比,即: 该作业已等待时间 / 该作业所需 CPU 时间 不难看出,这个比值的分母是一个不变的量。随着时间的推移,一个作业的“已等待时间”会不断发生变化,也就是分子在不断地变化。显然,短作业比较容易获得较高的响应比。这是因为它的分母较小,只要稍加等待,整个比值就会很快上升。另一方面,长作业的分母虽然很大,但随着它等待时间的增加,比值也会逐渐上升,从而获得
17、较高的响应比。根据这种分析,可见“响应比高者优先”的作业调度算法,既照顾到了短作业的利益,也照顾到了长作业的利益,是对先来先服务以及短作业优先这两种调度算法的一种折中。 10短作业优先调度算法总能得到最小的平均周 转时间吗?为什么? 答: 短作业优先调度算法只有在所有作业同时到达后备作业队列时,才能得到最小的平均周转时间。如果各作业不是同时到达,这个结论是不成立的。可以用反例说明,例如,教材上举有如下例子:考虑有 5 个作业 A 到 E,运行时间分别是 2、 4、 1、 1、 1;到达时间分别是 0、 0、 3、 3、 3。按照短作业优先的原则,最初只有 A 和 B 可以参与选择,因为其他 3
18、个还没有到达。于是,运行顺序应该是 A、 B、 C、 D、 E。它们每个的周转时间分别是 2、 6、4、 5、 6,平均周转时间是 4.6。但如果按照顺序 B、 C、 D、 E、 A 来调度,它们每一个的周转时间成为 9、 4、 2、 3、 4,平均周转时间是 4.4。结果比短作业优先调度算法好。之所以会这样,就是因为这 5 个作业并没有同时到达。 四、计算 1有三个作业: 作业 到达时间 所需 CPU 时间 1 0.0 8 2 0.4 4 3 1.0 1 分别采用先来先服务和短作业优先作业调度算法。试问它们的平均周转时间各是什么?你是否还可以给出一种更好的调度算法,使其平均周转时间优于这两种
19、调度算法? 解: ( 1)采用先来先服务作业调度算法时的实施过程如下。 作业 到达时间 所需 CPU 时间 开始时间 完成时间 周转时间 1 0.0 8 0.0 8.0 8.0 2 0.4 4 8.0 12.0 11.6 3 1.0 1 12.0 13.0 12.0 这时,作业的调度顺序是 1 2 3。其平均周转时间为: ( 8 + 11.6 + 12) / 3 = 10.53 ( 2)采用短作业优先作业调度算法时的实施过程如下。 作业 到达时间 所需 CPU 时间 开始时间 完成时间 周转时间 操作系统习题解答 7 1 0.0 8 0.0 8.0 8.0 3 1.0 1 8.0 9.0 8.
20、0 2 0.4 4 9.0 13.0 12.6 这里要注意,在作业 1 运行完毕进行作业调度时,作业 2 和 3 都已经到达。由于是实行短作业优先作业调度算法,因此先调度作业 3 运行,最后调度作业 2 运行。所以,这时的作业调度顺序是 1 3 2。其平均周转时间为: ( 8 + 8 + 12.6) / 3 = 9.53 ( 3)还可以有更好的作业调度算法,使其平均周转时间优于这两种调度算法。例如,如果知道在作业 1 后面会来两个短作业,那么作业 1 到达后,先不投入运行。而是等所有作业到齐后,再按照短作业优先作业调度算法进行调度,具体实施过程如下。 作业 到达时间 所需 CPU 时间 开始时
21、间 完成时间 周转时间 3 1.0 1 1.0 2.0 1.0 2 0.4 4 2.0 6.0 5.6 1 0.0 8 6.0 14.0 14.0 这时的作业调度顺序是 3 2 1。其平均周转时间为: ( 1 + 5.6 + 14) / 3 = 6.87 2设有一组作业,它们的到达时间和所需 CPU 时间如下所示。 作业号 到达时间 所需 CPU 时间 1 9:00 70 分钟 2 9:40 30 分钟 3 9:50 10 分钟 4 10:10 5 分钟 分别采用先来先服务和短作业优先作业调度算法。试问它们的调度顺序、作业周转时间以及平均周转时间各是什么? 解: ( 1)采用先来先服务作业调度
22、算法时的实施过程如下。 作业号 到达时间 所需 CPU 时间 开始时间 完成时间 周转时间 1 9:00 70 分钟 9:00 10:10 70 分钟 2 9:40 30 分钟 10:10 10:40 60 分钟 3 9:50 10 分钟 10:40 10:50 60 分钟 4 10:10 5 分钟 10:50 10:55 45 分钟 这时,作业的调度顺序是 1 2 3 4。其平均周转时间为: ( 70 + 60 + 60 + 45) / 4 = 58.75 ( 2)采用短作业优先作业调度算法时的实施过程如下。 操作系统习题解答 8 作业号 到达时间 所需 CPU 时间 开始时间 完成时间 周
23、转时间 1 9:00 70 分钟 9:00 10:10 70 分钟 4 10:10 5 分钟 10:10 10:15 5 分钟 3 9:50 10 分钟 10:15 10:25 35 分钟 2 9:40 30 分钟 10:25 10:55 75 分钟 这时,作业的调度顺序是 1 4 3 2。其平均周转时间为: ( 70 + 5 + 35 + 75) / 4 = 46.25 3某系统有三个作业: 作业号 到达时间 所需 CPU 时间 1 8.8 1.5 2 9.0 0.4 3 9.5 1.0 系统确定在它们全部到达后,开始采用响应比高者优先调度算法,并忽略系统调度时间。试问对它们的调度顺序是什么
24、?各自的周转时间是多少? 解: 三个作业是在 9.5 时全部到达的。这时它们各自的响应比如下: 作业 1 的响应比 =( 9.5 8.8) / 1.5 = 0.46 作业 2 的响应比 =( 9.5 9.0) / 0.4 = 1.25 作业 3 的响应比 =( 9.5 9.5) / 1.0 = 0 因此,最先应该调度作业 2 运行,因为它的响应比最高。它运行了 0.4 后完成,这时的时间是 9.9。再计算作业 1 和 3 此时的响应比: 作业 1 的响应比 =( 9.9 8.8) / 1.5 = 0.73 作业 3 的响应比 =( 9.9 9.5) / 1.0 = 0.40 因此,第二个应该调
25、度作业 1 运行,因为它的响应比最高。它运行了 1.5 后完成,这时的时间是 11.4。第三个调度的是作业 3,它运行了 1.0 后完成,这时的时间是 12.4。整个实施过程如下。 作业号 到达时间 所需 CPU 时间 开始时间 完成时间 周转时间 2 9.0 0.4 9.5 9.9 0.9 1 8.8 1.5 9.9 11.4 2.6 3 9.5 1.0 11.4 12.4 2.9 作业的调度顺序是 2 1 3。各自的周转时间为:作业 1 为 0.9;作业 2 为 2.6;作业 3为 2.9。 操作系统习题解答 9 第 4章 第 3 章 一、填空 1将作业相对地址空间的相对地址转换成内存中的
26、绝对地址的过程称为 地址重定位 。 2使用覆盖与对换技术的主要目的是 提高内存的利用率 。 3 存储管理中,对存储空间的浪费是以 内部碎片 和 外部碎片 两种形式表现出来的。 4地址重定位可分为 静态重定位 和 动态重定位 两种。 5 在可变分区存储管理中采用最佳适应算法时,最好按 尺寸 法来组织空闲分区链表。 6在分页式存储管理的页表里,主要应该包含 页号 和 块号 两个信息。 7静态重定位在程序 装入 时进行,动态重定位在程序 执行 时进行。 8在分页式存储管理中,如果页面置换算法选择不当,则会使系统出现 抖动 现象。 9在请求分页式存储管理中采用先进先出( FIFO)页面淘汰算法时,增加
27、分配给作业的块数时, 缺页中断 的次数有可能会增加。 10在请求分页式存储管理中,页面淘汰是 由于 缺页 引起的。 二、选择 1虚拟存储器的最大容量是由 B 决定的。 A内、外存容量之和 B计算机系统的地址结构 C作业的相对地址空间 D作业的绝对地址空间 2采用先进先出页面淘汰算法的系统中,一进程在内存占 3 块(开始为空),页面访问序列为 1、 2、 3、 4、 1、 2、 5、 1、 2、 3、 4、 5、 6。运行时会产生 D 次缺页中断。 A 7 B 8 C 9 D 10 从图 3-8 中的“缺页计数”栏里可以看出应该选择 D。 1 2 3 4 1 2 5 1 2 3 4 5 6 1
28、2 3 4 1 2 5 5 5 3 4 4 6 1 2 3 4 1 2 2 2 5 3 3 4 1 2 3 4 1 1 3 页面走向 3 个内存块 缺页计数 缺页计数 1 2 5 5 图 3-8 选择题 2 配图 3系统出现“抖动”现象的主要原因是由于 A 引起的。 A置换算法选择不当 B交换的信息量太大 C内存容量不足 D采用页式存储管理策略 4实现虚拟存储器的目的是 D 。 A进行存储保护 B允许程序浮动 C允许程序移动 D扩充主存容量 5作业在执行中发生了缺页中断,那么经中断处理后,应返回执行 B 指令。 A被中断的前一条 B被中断的那条 C被中断的后一条 D程序第一条 6在实行分页式存
29、储管理系统中,分页是由 D 完成的。 操作系统习题解答 10 A程序员 B用户 C操作员 D系统 7下面的 A 页面淘汰算法有时会产生异常现象。 A先进先出 B最近最少使用 C最不经常使用 D最佳 8在一个分页式存储管理系统中,页表的内容为: 若页的大小为 4KB,则地址转换机构将相对地址0 转换成的物理地址是 A 。 A 8192 B 4096 C 2048 D 1024 注意,相对地址 0 肯定是第 0 页的第 0 个字节。查页表可知第 0 页存放在内存的第 2块。现在块的尺寸是 4KB,因此第 2 块的起始地址为 8192。故相对地址 0 所对应的绝对地址(即物理地址)是 8192。 9
30、下面所列的存储管理方案中, A 实行的不是动态重定位。 A固定分区 B可变分区 C分页式 D请求分页式 10在下面所列的诸因素中,不对缺页中断次数产生影响的是 C 。 A内存分块的尺寸 B程序编制的质量 C作业等待的时间 D分配给作业的内存块数 三、问答 1什么是内部碎片?什么是外部碎片?各种存储管理中都可能 产生何种碎片? 答: 所谓“内部碎片”,是指系统已经分配给用户使用、用户自己没有用到的那部分存储空间;所谓“外部碎片”,是指系统无法把它分配出去供用户使用的那部分存储空间。对于教材而言,单一连续区存储管理、固定分区存储管理、分页式存储管理和请求页式存储管理都会出现内部碎片。只是前两种存储
31、管理造成的内部碎片比较大,浪费较为严重;后两种页式存储管理,平均来说每个作业都会出现半页的内部碎片。教材中,只有可变分区存储管理会产生外部碎片。 2叙述静态重定位与动态重定位的区别。 答: 静态重定位是一种通过软件来完成的地址 重定位技术。它在程序装入内存时,完成对程序指令中地址的调整。因此,程序经过静态重定位以后,在内存中就不能移动了。如果要移动,就必须重新进行地址重定位。 动态重定位是一种通过硬件支持完成的地址重定位技术。作业程序被原封不动地装入内存。只有到执行某条指令时,硬件地址转换机构才对它里面的地址进行转换。正因为如此,实行动态重定位的系统,作业程序可以在内存里移动。也就是说,作业程序在内存中是可浮动的。 3一个虚拟地址结构用 24 个二进制位表示。其中 12 个二进制位表示页面尺寸。试问这种虚拟地址空间总共多少页?每页的尺寸 是多少? 答: 如下图所示,由于虚拟地址中是用 12 个二进制位表示页面尺寸(即页内位移),所以虚拟地址空间中表示页号的也是 12 个二进制位。这样,这种虚拟地址空间总共有: 212 = 4096(页) 每页的尺寸是: 212 = 4096 = 4K(字节) 页号 块号 0 2 1 1 2 7