计算机操作系统教程课后答案Word文档格式.docx
《计算机操作系统教程课后答案Word文档格式.docx》由会员分享,可在线阅读,更多相关《计算机操作系统教程课后答案Word文档格式.docx(20页珍藏版)》请在冰点文库上搜索。
20
上述这些观点彼此并不矛盾,只不过代表了同一事物(操作系统)站在不同的角度来看待。
每一种观点都有助于理解、分析和设计操作系统。
第二章 作业管理和用户接口
1.什么是作业?
作业步?
把在一次应用业务处理过程中,从输入开始到输出结束,用户要求计算机所做的有关该次业务处理的全部工作称为一个作业。
作业由不同的顺序相连的作业步组成。
作业步是在一个作业的处理过程中,计算机所做的相对独立的工作。
如,编辑输入是一个作业步,它产生源程序文件;
编译也是一个作业步,它产生目标代码文件。
2.作业由哪几部分组成?
各有什么功能?
作业由三部分组成:
程序、数据和作业说明书。
程序和数据完成用户所要求的业务处理工作,作业说明书则体现用户的控制意图。
3.作业的输入方式有哪几种?
各有何特点
作业的输入方式有5种:
联机输入方式、脱机输入方式、直接耦合方式、SPOOLING
(SimultaneousPeripheralOperationsOnline)系统和网络输入方式,各有如下特点:
(1)联机输入方式:
用户和系统通过交互式会话来输入作业。
(2)脱机输入方式:
又称预输入方式,利用低档个人计算机作为外围处理机进行输入处理,存储在后备存储器上,然后将此后援存储器连接到高速外围设备上和主机相连,从而在较短的时间内完成作业的输入工作。
(3)直接耦合方式:
把主机和外围低档机通过一个公用的大容量外存直接耦合起来,从而省去了在脱机输入中那种依靠人工干预宋传递后援存储器的过程。
(4)SPOOLING系统:
可译为外围设备同时联机操作。
在SPOOLING系统中,多台外围设备通过通道或DMA器件和主机与外存连接起来,作业的输入输出过程由主机中的操作系统控制。
(5)网络输入方式:
网络输入方式以上述几种输入方式为基础,当用户需要把在计算机网络中某一台主机上输入的信息传送到同一网中另一台主机上进行操作或执行时,就构成了网络输入方式。
4.试述SPOOLING系统的工作原理。
操作系统中的输入程序包含两个独立的过程,一个过程负责从外部设备把信息读入缓冲区,另一个过程是写过程,负责把缓冲区中的信息送入到外存输入井中。
在系统输入模块收到作业输入请求后,输入管理模块中的读过程负责将信息从输入装置读入缓冲区。
当缓冲区满时,由写过程将信息从缓冲区写到外存输入井中。
读过程和写过程反复循环,直到一个作业输入完毕。
当读过程读到一个硬件结束标志后,系统再次驱动写过程把最后一批信息写入外存并调用中断处理程序结束该次输入。
然后,系统为该作业建立作业控制块JCB,从而使输入井中的作业进入作业等待队列,等待作业调度程序选中后进入内存。
5.作业说明书和作业控制块有何异同?
作业说明书主要包含三方面内容:
作业的基本描述、作业控制描述和资源要求描述。
作业基本描述主要包括用户名、作业名、使用的编程语言名、允许的最大处理时间等。
而作业控制描述则大致包括作业在执行过程中的控制方式,例如是脱机控制还是联机控制、各作业步的操作顺序以及作业不能正常执行时的处理等。
资源要求描述包括要求内存大小、外设种类和台数、处理机优先级、所需处理时间、所需库函数或实用程序等。
而作业控制块是作业说明书在系统中生成的一张表格,该表格登记该作业所要求的资源情况、预计执行时间和执行优先级等。
从而,操作系统通过该表了解到作业要求,并分配资源和控制作业中程序和数据的编译、链接、装入和执行等。
6.操作系统为用户提供哪些接口?
它们的区别是什么?
操作系统为用户提供两个接口,一个是系统为用户提供的各种命令接口,用户利用这些操作命令来组织和控制作业的执行或管理计算机系统。
另一个接口是系统调用,编程人员使用系统调用来请求操作系统提供服务,例如申请和释放外设等类资源、控制程序的执行速度等。
7.作业控制方式有哪几种?
调查你周围的计算机的作业控制方式。
作业控制的主要方式有两种:
脱机方式和联机方式。
脱机控制方式利用作业控制语言来编写表示用户控制意图的作业控制程序,也就是作业说明书。
作业控制语言的语句就是作业控制命令。
不同的批处理系统提供不同的作业控制语言。
联机控制方式不同于脱机控制方式,它不要求用户填写作业说明书,系统只为用户提供一组键盘或其他操作方式的命令。
用户使用操作系统提供的操作命令和系统会话,交互地控制程序执行和管理计算机系统。
8.什么是系统调用?
系统调用与一般用户程序有什么区别?
与库函数和实用程序又有什么区别?
系统调用是操作系统提供给编程人员的唯一接口。
编程人员利用系统调用,在源程序一级动态请求和释放系统资源,调用系统中已有的系统功能来完成那些与机器硬件部分相关的工作以及控制程序的执行速度等。
因此,系统调用像一个黑箱子那样,对用户屏蔽了操作系统的具体动作而只提供有关的功能。
它与一般用户程序、库函数和实用程序的区别是:
系统调用程序是在核心态执行,调用它们需要一个类似于硬件中断处理的中断处理机制来提供系统服务。
9.简述系统调用的实现过程。
用户在程序中使用系统调用,给出系统凋用名和函数后,即产生一条相应的陷入指令,通过陷入处理机制调用服务,引起处理机中断,然后保护处理机现场,取系统调用功能号并寻找子程序入口,通过入口地址表来调用系统子程序,然后返回用户程序继续执行。
10.为什么说分时系统没有作业的概念?
因为在分时系统中,每个用户得到的时间片有限,用户的程序和数据信息直接输入到内存工作区中和其他程序一起抢占系统资源投入执行,而不必进入外存输入井等待作业调度程序选择。
因此,分时系统没有作业控制表,也没有作业调度程序。
11.试述UNIX的主要特点。
UNIX的主要特点是:
(1)UNIX系统是一个可供多用户同时操作的交互式分时操作系
统,
(2)为了向用户提供交互式功能和使得用户可以利用UNIX系统的功能,UNIX系统向用户提供了两种友好的界面或接口:
系统调用和命令;
(3)UNIX系统具有一个可装卸的分层树型结构文件系统,该文件系统使用方便、搜索简单,
(4)UNIX系统把所有外部设备都当成文件,并分别赋予它们对应的文件名。
从而,用户可以像使用文件那样使用任一设备而不必了解该设备的内部特性,这既简化了系统设计,又方便了用户;
(5)UNIX系统核心程序的绝大部分源代码和系统上的支持软件都用C语言编写。
且UNIX系统是一个开放式系统,即具有统一的用户接口,使得
UNIX用户的应用程序可在不同的执行环境下运行。
正是由于UNIX具有上述这些特点,使得UNIX系统得到了广泛的
应用和发展。
12.UNIX操作系统为用户提供哪些接口?
试举例说明。
UNIX系统为用户提供两个接口,即面向操作命令的接口Shell和面向编程用户的接口:
系统调用。
常见的Shell命令如:
login,logout,vi,emacs,印,rm,ls,cc,link,
adduser,chown,dbx,date等;
常见的系统调用如:
ioctl,
read,write,open,close,
creat,execl,flock,stat,mount,fork,wait,exit,socket
等。
13.在你周围装有UNIX系统的计算机上,练习使用后台命令、管道命令等Shell
的基本命令。
例1:
用Shell语言编制一Shell程序,该程序在用户输入年、月之后,自动打印输出该年该月的日历:
echo"
Pleaseinputthemonth:
”readmonth
echo'
'
Pleaseinputtheyear:
”readyear
第三章 用户管理和配置管理
1.有A说,一个进程是由伪处理机执行的一个程序,这话对吗?
为什么?
答:
对。
因为伪处理机的概念只有在执行时才存在,它表示多个进程在单处理机上并发执行的二个调度单位。
因此,尽管进程是动态概念,是程序的执行过程,但是,在多个进程并行执行时,仍然只有一个进程占据处理机执行,而其他并发进程则处于就绪或等待状态。
这些并发进程就相当于由伪处理机执行的程序。
2.试比较进程和程序的区别。
(1)进程是一个动态概念,而程序是一个静态概念,程序是指令的有序集合,无执行含义,进程则强调执行的过程。
(2)进程具有并行特征(独立性,异步性),程序则没有。
(3)不同的进程可以包含同一个程序,同一程序在执行中也可以产生多个进程。
3.我们说程序的并发执行将导致最终结果失去封闭性广这话对所有的程序都成立吗?
举例说明.
并非所有程序均成立。
如:
Beginlocal“ZK:
:
10print(x)End
上述程序中x是内部变量,不可能被外部程序访问,因此这段程序的运行不会受外部环境影响。
4.试比较作业和进程的区别。
一个进程是一个程序对某个数据集的执行过程,是分配资源的基本单位。
作业是用于需要计算机完成某项任务,而要求计算机所做工作的集合。
一个作业的完成要经过作业提交,作业收容、作业执行和作业完成4个阶段。
而进程是已提交完毕的程序所执行过程的描述,足资源分配的基本单位。
其主要区别关系如下:
(1)作业是用户向计算机提交任务的任务实体。
在用户向计算机提交作业之后,系统将存储在外存中的作业等待队列中等待执行。
而进程则是完成用户任务的执行实体,是向系统申请分配资源的基本单位。
任一进程,只要它被创建,总有相应的部分存在于内存中。
(2)一个作业可由多个进程组成。
且必须至少由一个进程组成,但反过来不成立。
(3)作业的概念主要用在批处理系统中。
像Unix这样的分时系统中,则没有作业概念。
而进程的概念则用在几乎所有的多道程序系统中。
5.UNIXSystemV中,系统程序所对应的正文段未被考虑成进程上下文的一部分,为什么?
因为系统程序的代码被用户程序所共享,因此如果每个进程在保存进程上下文时,都将系统程序代码放到其进程上下文中,则大大浪费了资源。
因此系统程序的代码不放在进程上下文中,而是统一放在核心程序所处的内存中。
6.什么是临界区?
试举一临界区的例子。
临界区是指不允许多个并发进程交叉执行的一段程序。
它是由于不同并发进程的程序段共享公用数据或公用数据变量而引起的。
所以它又被称为访问公用数据的那段程序。
例如:
getspace:
Beginlocalgtop=top-1
Endrelease(ad):
Begin
top’top十1stack[top]=adEnd
7.并发进程间的制约有哪两种?
引起制约的原因是什么?
并发进程所受的制约有两种:
直接制约和间接制约。
直接制约是由并发进程互相共享对方的私有资源所引起的。
间接制约是由竞争共有资源而引起的。
8.什么是进程间的互斥?
什么是进程间同步?
进程间的互斥是指:
一组并发进程中的一个或多个程序段,因共享某一公有资源而导致它们必须以一个不许交叉执行的单位执行,即不允许两个以上的共享该资源的并发进程同时进入临界区。
进程间的同步是指:
异步环境下的一组并发进程因直接制约互相发送消息而进行互相合作、互相等待,各进程按一定的速度执行的过程。
9.试比较P,V原语法和加锁法实现进程间互斥的区别。
互斥的加锁实现是这样的:
当某个进程进入临界区之后,它将锁上临界区,直到它退出临界区时为止。
并发进程在申请进入临界区时,首先测试该临界区是否是上锁的,如果该临界区已被锁住,则该进程要等到该临界区开锁之后才有可能获得临界区。
但是加锁法存在如下弊端:
(1)循环测试锁定位将损耗较多的CPU计算时间;
(2)产生不公平现象。
为此,P,V原语法采用信号量管理相应临界区的公有资源,信号量的数值仅能由P,V原语操作改变,而P,V原语执行期间不允许中断发生。
其过程是这样的:
当某个进程正在临界区内执行时,其他进程如果执行了P原语,则该进程并不像lock时那样因进不了临界区而返回到lock的起点,等以后重新执行测试,而是在等待队列中等待由其他进程做
V原语操作释放资源后,进入临界区,这时P原语才算真正结束。
若有多个进程做P原语操作而进入等待状态之后,一旦有V原语释放资源,则等待进程中的一个进入临界区,其余的继续等待。
总之,加锁法是采用反复测试lock而实现互斥的,存在CPU浪费和不公平现像,
P,V原语使用了信号量,克服了加锁法的弊端。
15.什么是线程?
试述线程与进程的区别,
线程是在进程内用于调度和占有处理机的基本单位,它由线程控制表、存储线程上下文的用户栈以及核心栈组成。
线程可分为用户级线程、核心级线程以及用户/核心混合型线程等类型。
其中用户级线程在用户态下执行,CPU调度算法和各线程优先级都由用户设置,与操作系统内核无关。
核心级线程的调度算法及线程优先级的控制权在操作系统内核。
混合型线程的控制权则在用户和操作系统内核二者。
线程与进程的主要区别有:
(1)进程是资源管理的基本单位,它拥有自己的地址空间和各种资源,例如内存空间、外部设备等;
线程只是处理机调度的基本单位,它只和其他线程一起共享进程资源,但自己没有任何资源。
(2)以进程为单位进行处理机切换和调度时,由于涉及到资源转移以及现场保护等问题,将导致处理机切换时间变长,资源利用率降低。
以线程为单位进行处理机切换和调度时,由于不发生资源变化,特别是地址空间的变化,处理机切换的时间较短,从而处理机效率也较高。
(3)对用户来说,多线程可减少用户的等待时间。
提高系统的响应速度。
例如,当一个进程需要对两个不同的服务器进行远程过程凋用时,对于
无线程系统的操作系统来说需要顺序等待两个不同调用返回结果后才能继续执行,且在等待中容易发生进程调度。
对于多线程系统而言,则可以在同一进程中使用不同的线程同时进行远程过程调用,从而缩短进程的等待时间。
(4)线程和进程一样,都有自己的状态.也有相应的同步机制,不过,由于线程没有单独的数据和程序空间,因此,线程不能像进程的数据与程序那样,交换到外存存储空间。
从而线程没有挂起状态。
(5)进程的调度、同步等控制大多由操作系统内核完成,而线程的控制既可以由操作系统内核进行,也可以由用户控制进行。
第四章 进程管理
1.什么是分级调度?
分时系统中有作业调度的概念吗?
如果没有,为什么?
处理机调度问题实际上也是处理机的分配问题。
显然只有那些参与竞争处理及所必需的资源都已得到满足的进程才能享有竞争处理机的资格。
这时它们处于内存就绪状态。
这些必需的资源包括内存、外设及有关数据结构等。
从而,在进程有资格竞争处理机之前,作业调度程序必须先调用存储管理、外设管理程序,并按一定的选择顺序和策略从输入井中选择出几个处于后备状态的作业,为它们分配资源和创建进程,使它们获得竞争处理机的资格。
另外,由于处于执行状态下的作业一般包括多个进程,而在单机系统中,每一时刻只能有一个进程占有处理机,这样,在外存中,除了处于后备状态的作业外,还存在处于就绪状态而等待得到内存的作业。
我们需要有一定的方法和策略为这部分作业分配空间。
因此处理机调度需要分级。
一般来说,处理机调度可分为4级;
(1)作业调度:
又称宏观调度,或高级调度。
(2)交换调度:
又称中级调度。
其主要任务是按照给定的原则和策略,将处于外存交换区中的就绪态或等待状态或内存等待状态的进程交换到外存交换区。
交换调度主要涉及到内存管理与扩充。
因此在有些书本中也把它归入内存管理部分。
(3)进程调度:
又称微观调度或低级调度。
其主要任务是按照某种策略和方法选取一个处于就绪状态的进程占用处理机。
在确立了占用处理机的进程之后,系统必须进行进程上下文切换以建立与占用处理机进程相适应的执行环境。
(4)线程调度:
进程中相关堆栈和控制表等的调度。
在分时系统中,一般不存在作业调度,而只有线程调度、进程调度和交换调度。
这是因为在分时系统中,为了缩短响应时间,作业不是建立在外存,而是直接建立在内存中。
在分时系统中,一旦用户和系统的交互开始,用户马上要进行控制。
因此,分时系统中没有作业提交状态和后备状态。
分时系统的输入信息经过终端缓冲区为系统直接接收,或立即处理,或经交换调度暂存外存
中。
2.试述作业调度的主要功能。
答:
作业调度的主要功能是:
按一定的原则对外存输入井上的大量后备作
业进行选择,给选出的作业分配内存、输入输出设备等必要的资源,并建立相应进程,使该作业的相关进程获得竞争处理机的权利。
另外,当作业执行完毕时,还负责回收系统资源。
3.作业调度的性能评价标准有哪些?
这些性能评价标准在任何情况下都能反映调度策略的优劣吗?
对于批处理系统,由于主要用于计算,因而对于作业的周转时间要求较高。
从而作业的平均周转时间或平均带权周转时间被用来衡量调度程序的优劣。
但对于分时系统来说,平均响应时间又被用来衡量调度策略的优劣。
对于分时系统, 除了要保证系统吞吐量大、资源利用率高之外,还应保证用户能够容忍的响应时间。
因此,在分时系统中,仅仅用周转时间或带权周转时间来衡量调度性能是不够的。
对于实时系统, 衡量调度算法优劣的主要标志则是满足用户要求的时限时间。
4.进程调度的功能有哪些?
进程调度的功能有:
(1)记录和保存系统中所有进程的执行情况;
(2)选择占有处理机的进程;
(3)进行进程上下文切换。
5.进程调度的时机有哪几种?
进程调度的时机有:
(1)正在执行的进程执行完毕。
这时如果不选择新的就绪进程执行,将浪费处理机资源。
(2)执行中进程自己调用阻塞原语将自己阻塞起来进入睡眠等待
状态。
(3)执行中进程调用了P原语操作,从而因资源不足而被阻塞:
或
调用了V原语操作激活了等待资源的进程队列。
(4)执行中进程提出I/O请求后被阻塞。
(5)在分时系统中时间片已经用完。
(6)在执行完系统调用等系统程序后返回用户程序时,可看做系统进程执行完毕,从而调度选择一新的用户进程执行。
(7)在CPU执行方式是可剥夺时,还有:
就绪队列中的某进程的优先级变得高于当前执行进程的优先级,从而也将引发进 程调度。
6.进程上下文切换由哪几部分组成?
描述进程上下文切换过程。
进程上下文切换由以下4个步骤组成;
(1)决定是否作上下文切换以及是否允许作上下文切换。
包括对进程调度原因的检查分析,以及当前执行进程的资格和CPU执行方式的检查等。
在操作系统中,上下文切换程序并不是每时每刻都在检查和分析是否可作上下文切换,它们设置有适当的时机。
(2)保存当前执行进程的上下文。
这里所说的当前执行进程,实际上是指调用上下文切换程序之前的执行进程。
如果上下文切换不是被那个当前执行进程所调用,且不属于该进程,则所保存的上下文应是先前执行进程的上下文,或称为“老”进程上下文。
显然,上下文切换程序不能破坏“老”进程的上下文结构。
(3)使用进程调度算法,选择一处于就绪状态的进程。
(4)恢复或装配所选进程的上下文,将CPU控制权交到所选进程手
7.为什么说在进程上下文切换过程中,上下文切换程序不能破坏“老”进程的上下文结构?
因为如果在进程上下文切换中破坏了老的进程上下文,等到CPU调度到该老进程执行时,就不能正确地恢复其停止执行前的状态了。
第五章 处理器管理
1.存储管理的主要功能是什么?
存储管理的主要功能包括以下几点:
(1)在硬件的支持下完成统一管理内存和外存之间数据和程序段自动交换的虚拟存储
(2)将多个虚存的一维线性空间或多维线性空间变换到内存的唯一的一维物理线性地
(3)控制内外存之间的数据传输。
(4)实现内存的分配和回收。
(5)实现内存信息的共享与保护。
2.什么是虚拟存储器?
其特点是什么?
由进程中的目标代码、数据等的虚拟地址组成的虚拟空间称为虚拟存储器。
虚拟存储器不考虑物理存储器的大小和信息存放的实际位置,只规定每个
进程中相互关联信息的相对位置。
每个进程都拥有自己的虚拟存储器,且虚拟存储器的容量是由计算机的地址结构和寻址方式来确定。
实现虚拟存储器要求有相应的地址转换机构,以便把指令的虚拟地址变换为实际物理地址;
另外,由于内存空间较小,进程只有部分内容存放于内存中,待执行时根据需要再调指令入内存。
3.实现地址重定位的方法有哪几类?
实现地址重定位的方法有两种:
静态地址重定位和动态地址重定位。
(1)静态地址重定位是在虚空间程序执行之前由装配程序完成地址映射工作。
静态重定位的优点是不需要硬件支持,但是用静态地址重定位方法进行地址变换无法实现虚拟存储器。
静态重定位的另一个缺点是必须占用连续的内存空间和难以做到程序和数据的共享。
(2)动态地址重定位是在程序