《操作系统各章习题及答案.pdf》由会员分享,可在线阅读,更多相关《操作系统各章习题及答案.pdf(6页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 第一章1.设计现代 0S 的主要目标是什么?方便性,有效性,可扩充性和开放性.2.OS 的作用可表现为哪几个方面?a.OS 作为用户与计算机硬件系统之间的接口;b.Os 作为计算机系统资源的管理者;c.Os 作为扩充机器.3,试说明推动多道批处理系统形成和发展的主要动力是什么?不断提高计算机资源利用率和系统吞吐量的需要;4.何谓脱机工/0 和联机工/0?a.脱机输入输出方式(off 一 Line 工/0)是为了解决人机矛盾及 CPU 和工/0 设备之间速度不匹配而提出的.它减少了 CPU 的空闲等待时间,提高了 1/0 速度.具体内容是将用户程序和数据在一台外围机的控制下,预先从低速输入设备
2、输入到磁带上,当 CPU 需要这些程序和数据时,在直接从磁带机高速输入到内存,从而大大加快了程序的输入过程,减少了 CPU 等待输入的时间,这就是脱机输入技术;当程序运行完毕或告一段落,CPU 需要输出时,无需直接把计算结果送至低速输出设备,而是高速把结果输出到磁带上,然后在外围机的控制下,把磁带上的计算结果由相应的输出设备输出,这就是脱机输出技术.b.若这种输入输出操作在主机控制下进行则称之为联机输入输出方式.5.试说明推动分时系统形成和发展的主要动力是什么?用户的需要.即对用户来说,更好的满足了人机交互,共享主机以及便于用户上机的需求.6,试说明实时任务的类型和实时系统的类型.a.实时任务
3、的类型按任务执行时是否呈现周期性来划分,分为周期性实时任务和非周期性实时任务;根据对截止时间的要求来划分,分为硬实时任务和软实时任务;b.通常把要求进行实时控制的系统统称为实时控制系统,把要求对信息进行实时处理的系统成为实时信息处理系统.7.实现多道程序应解决哪些问题?a.处理机管理问题;b.内存管理问题;c.1/0 设备管理问题;d.文件管理问题;e.作业管理问题.8,试比较单道与多道批处理系统的特点及优缺点,a.单道批处理系统是最早出现的一种 0S,它具有自动性,顺序性和单道性的特点;多道批处理系统则具有调度性,无序性和多道性的特点;b.单道批处理系统是在解决人机矛盾及 CPU 和工/0
4、设备之间速度不匹配的矛盾中形成的,旨在提高系统资源利用率和系统吞吐量,但是仍然不能很好的利用系统资源;多道批处理系统是对单道批处理系统的改进,其主要优点是资源利用率高,系统吞吐量大;缺点是平均周转时间长,无交互能力.9,实现分时系统的关键问题是什么?应如何解决?a.关键问题:及时接收,及时处理;b.对于及时接收,只需在系统中设置一多路卡,多路卡作用是使主机能同时接收用户从各个终端上输入的数据;对于及时处理,应使所有的用户作业都直接进入内存,在不长的时间内,能使每个作业都运行一次.10 为什么要引入实时操作系统?更好地满足实时控制领域和实时信息处理领域的需要.11.0s 具有哪几大特征?它的最基
5、本特征是什么?a.并发(Concurrence),共享(Sharing),虚拟(Virtual),异步性(ASynchronism).b.其中最基本特征是并发和共享.12 内存管理有哪些主要功能?它们的主要任务是什么?a.主要功能:内存分配,内存保护,地址映射和内存扩充等.b.内存分配的主要任务是为每道程序分配内存空间,提高存储器利用率,以减少不可用的内存空间,允许正在运行的程序申请附加的内存空间,以适应程序和数据动态增长的需要.-内存保护的主要任务是确保每道用户程序都在自己的内存空间中运行,互不干扰.-地址映射的主要任务是将地址空间中的逻辑地址转换为内存空间中与之对应的物理地址.-内存扩充的
6、主要任务是借助虚拟存储技术,从逻辑上去扩充内存容量.13 处理机管理具有哪些功能?它们的主要任务是什么?a.进程控制,进程同步,进程通信和调度.b.进程控制的主要任务是为作业创建进程,撤销已结束的进程,以及控制进程在运行过程中的状态转换.-一进程同步的主要任务是对诸进程的运行进行调节.-一进程通信的任务是实现在相互合作进程之间的信息交换.-一调度分为作业调度和进程调度.作业调度的基本任务是从后备队列中按照一定的算法,选择出若干个作业,为它们分配必要的资源;而进程调度的任务是从进程的就绪队列中,按照一定的算法选出一新进程,把处理机分配给它,并为它设置运行现场,是进程投入运行.14 设备管理有哪些
7、主要功能?其主要任务是什么?a.主要功能:缓冲管理,设备分配和设备处理,以及虚拟设备等.b.主要任务:完成用户提出的 1/0 请求,为用户分配 1/0 设备;提高 CPU 和 1/0 设备的利用率;提高1/0 速度;以及方便用户使用 1/0 设备.15 文件管理有哪些主要功能?其主要任务是什么?a.主要功能:对文件存储空间的管理,目录管理,文件的读,写管理以及文件的共享和保护.b.主要任务:对用户文件和系统文件进行管理,以方便用户使用,并保证文件的安全性.16 试在交互性,及时性和可靠性方面,将分时系统与实时系统进行比较,a.分时系统是一种通用系统,主要用于运行终端用户程序,因而它具有较强的交
8、互能力;而实时系统虽然也有交互能力,但其交互能力不及前者.b.实时信息系统对实用性的要求与分时系统类似,都是以人所能接收的等待时间来确定;而实时控制系统的及时性则是以控制对象所要求的开始截止时间和完成截止时间来确定的.c.实时系统对系统的可靠性要求要比分时系统对系统的可靠性要求高.17 是什么原因使操作系统具有异步性特征?a.程序执行结果是不确定的,即程序是不可再现的.第二章 3.程序并发执行为什么会产生间断性?因为程序在并发执行过程中存在相互制约性.4,程序并发执行为何会失去封闭性和可再现性?因为程序并发执行时,多个程序共享系统中的各种资源,资源状态需要多个程序来改变,即存在资源共享性使程序
9、失去封闭性;而失去了封闭性导致程序失去可再现性.5.在操作系统中为什么要引入进程概念?它会产生什么样的影响?为了使程序在多道程序环境下能并发执行,并能对并发执行的程序加以控制和描述,而引入了进程概念.影响:使程序的并发执行得以实行.6.试从动态性,并发性和独立性上比较进程和程序?a.动态性是进程最基本的特性,可表现为由创建而产生,由调度而执行,因得不到资源而暂停执行,以及由撤销而消亡,因而进程由一定的生命期;而程序只是一组有序指令的集合,是静态实体.b.并发性是进程的重要特征,同时也是 0S 的重要特征.引入进程的目的正是为了使其程序能和其它进程的程序并发执行,而程序是不能并发执行的.c.独立
10、性是指进程实体是一个能独立运行的基本单位,同时也是系统中独立获得资源和独立调度的基本单位.而对于未建立任何进程的程序,都不能作为一个独立的单位参加运行.7.试说明 PCB 的作用?为什么说 PCB 是进程存在的唯一标志?a.PCB 是进程实体的一部分,是操作系统中最重要的记录型数据结构.PCB 中记录了操作系统所需的用于描述进程情况及控制进程运行所需的全部信息.因而它的作用是使一个在多道程序环境下不能独立运行的程序(含数据),成为一个能独立运行的基本单位,一个能和其它进程并发执行的进程.b.在进程的整个生命周期中,系统总是通过其 PCB 对进程进行控制,系统是根据进程的 PCB 而不是任何别的
11、什么而感知到该进程的存在的,所以说,PCB 是进程存在的唯一标志.8.试说明进程在三个基本状态之间转换的典型原因.a.处于就绪状态的进程,当进程调度程序为之分配了处理机后,该进程便由就绪状态变为执行状态.b.当前进程因发生某事件而无法执行,如访问已被占用的临界资源,就会使进程由执行状态转变为阻塞状态.c.当前进程因时间片用完而被暂停执行,该进程便由执行状态转变为就绪状态.9,为什么要引入挂起状态?该状态具有哪些性质?a.引入挂起状态处于 5 中需要:终端用户的需要,父进程的需要,操作系统的需要,对换的需要和负荷调节的需要.b.处于挂起状态的进程不能接收处理机调度.10 在进行进程切换时,所要保
12、存的处理机状态信息主要有哪些?a.进程当前暂存信息;b.下一条指令地址信息;c.进程状态信息;d.过程和系统调用参数及调用地址信息.13 在创建一个进程时,需完成的主要工作是什么?a.操作系统发现请求创建新进程事件后,调用进程创建原语 Creat();b.申请空白 PCB;c.为新进程分配资源;d.初始化进程控制块;e.将新进程插入就绪队列.14 在撤消一个进程时,需完成的主要工作是什么?a.Os 调用进程终止原语;b.根据被终止进程的标志符,从 PCB 集合中检索出该进程的 PCB,从中读出该进程的状态;c.若被终止进程正处于执行状态,应立即中止该进程的执行,并设置调度标志为真;d.若该进程
13、还有子孙进程,还应将其所有子孙进程予以终止;e.将该进程所拥有的全部资源,或者归还给其父进程,或者归还给系统;f.将被终止进程(它的 PCB)从所在队列(或链表)中移出,等待其它程序来搜集信息.17.为什么进程在进入临界区之前,应先执行”进入区“代码,在退出临界区后又执行“退出区”代码?为了实现多个进程对临界资源的互斥访问,必须在临界区前面增加一段用于检查欲访问的临界资源是否正被访问的代码,如果未被访问,该进程便可进入临界区对资源进行访问,并设置正被访问标志,如果正被访问,则本进程不能进入临界区,实现这一功能的代码成为”进入区”代码;在退出临界区后,必须执行”退出区”代码,用于恢复未被访问标志
14、.18,同步机构应遵循哪些基本准则?为什么?a.空闲让进.b.忙则等待.c 有限等待.d.让权等待.23 在生产者一消费者问题中,如果缺少了 signal(full)或 Signal(empty),对执行结果会有何影响?如果缺少了 signal(full)或 Signal(empty),生产者可以不断地往缓冲池送消息,如果缓冲池满,就会覆盖原有数据,造成数据混乱.而消费者始终因 wait(full)操作将消费进程直接送入进程阻塞链表进行等待,无法访问缓冲池,造成无限等待.24,在生产者一消费者问题中,如果将两个 wait 操作即 wait(full)和 wait(mutex)互换位置;或者是将
15、 signal(mutex)与 signal(full)互换位置结果会如何?a.wait(full)和 wait(mutex)互换位置后,因为 mutex 在这儿是全局变量,执行完 wait(mutex),则mutex 赋值为 0,倘若 full 也为 0,则该生产者进程就会转入进程链表进行等待,而生产者进程会因全局变量 mutex 为 0 而进行等待,使 full 始终为 0,这样就形成了死锁.b.而 signal(mutex)与 signal(full)互换位置后,从逻辑上来说应该是一样的.25,我们为某临界区设置一把锁 W,当 W=1 时,表示关锁;W=0 时,表示锁已打开.试写出开锁原
16、语和关锁原语,并利用它们去实现互斥,开锁原语:unlock(W):W=O;关锁原语:lock(W);if(W=l)do no_op;W=l;利用开关锁原语实现互斥:Var w:semaphore:=0;begin parbegin Process:begin repeat lock(W);critical section unlock(W);remainder section until false;end parend 26.试修改下面生产者一消费者问题解法中的错误:Producer:begin repeat producer an item in nextp;wait(mutex);wai
17、t(full);/*应为 wait(empty),而且还应该在 wait(mutex)的前面*/buffer(in):=nextp;/*缓冲池数组游标应前移:in:=(in+l)mod n;*/signal(mutex);/*signal(full);*/until false;end Consumer:begin repeat wait(mutex);wait(empty);/*应为 wait(full),而且还应该在 wait(mutex)的前面*/nextc:=buffer(out);out:=out+l;/*考虑循环,应改为:out:=(out+l)mod n;*/signal(mutex);/*signal(empty);*/consumer item in nextc;until false;end 27 试利用记录型信号量写出一个不会出现死锁的哲学家进餐问题的算法.设初始值为 1 的信号量 cI表示工号筷子被拿(工=l,2,3,4,Zn),其中 n 为自然数.send(I):Begin if 1 mod 2=1 then P(cI);P(cI1 mod 5);Eat;V(cI 一 1 mod 5);V(cI);e1se P(cI 一 1 mod 5);P(cI);Eat;V(cI);V(cI 一 1 mod 5);
限制150内