“操作系统概论”习题解答之并发进程
操作系统习题及答案一
操作系统习题及答案一操作系统习题及答案一1:进程管理1.1 进程概念1.1.1 什么是进程?进程是程序在计算机内部运行时的实例。
它包含了程序及其执行所需的资源(如内存空间、文件等)。
1.1.2 进程的特征有哪些?- 动态性:进程是动态地创建、销毁和调度的。
- 并发性:多个进程可以同时运行。
- 独立性:每个进程都有自己的独立执行序列。
- 资源占有性:每个进程有自己的独立空间和资源。
1.2 进程调度1.2.1 什么是进程调度?进程调度是操作系统决定应该从就绪队列中选择哪个进程执行的过程。
1.2.2 进程调度的目标是什么?- 提高资源利用率:尽可能多地利用CPU和其他资源。
- 提高系统响应速度:快速响应用户请求。
- 公平性:确保所有进程都能得到一定的执行机会。
- 避免饥饿:避免某些进程永远无法获得CPU时间。
1.2.3 常见的进程调度算法有哪些?- 先来先服务(FCFS):按照进程到达的顺序进行调度。
- 短作业优先(SJF):优先调度执行时间短的进程。
- 轮转调度(Round Robin):每个进程按照时间片轮流执行。
1.3 进程同步与互斥1.3.1 什么是进程同步?进程同步是为了协调多个进程的执行顺序,以确保它们按照预定的顺序访问共享资源。
1.3.2 进程同步的方法有哪些?- 互斥量(Mutex):通过对共享资源加锁实现互斥。
- 信号量(Semaphore):通过计数器实现对共享资源的控制。
- 事件(Event):通过等待和通知机制实现进程的同步和协作。
2:内存管理2.1 内存分配方式2.1.1 什么是内存分配?内存分配是将系统的可用内存分配给进程使用的过程。
2.1.2 常见的内存分配方式有哪些?- 连续内存分配:将进程的地址空间连续地分配在内存中。
- 非连续内存分配:将进程的地址空间分散地分配在内存中。
2.2 页面置换算法2.2.1 什么是页面置换?页面置换是将内存中的某些页面移出内存,以便为新的页面腾出空间的过程。
操作系统习题及答案一
操作系统习题及答案一操作系统是管理计算机硬件与软件资源的程序,同时也是计算机系统的内核与基石。
以下是一些操作系统相关的习题及答案。
习题一:进程与线程的区别进程是操作系统进行资源分配的基本单位,而线程是操作系统进行调度的基本单位。
请简述进程和线程的主要区别。
答案:进程和线程存在以下几个主要区别:1、资源拥有:进程拥有独立的地址空间和资源,如内存、文件等;线程共享所属进程的资源,但有自己的栈和寄存器等少量私有资源。
2、调度:进程切换开销较大,因为需要切换整个地址空间;线程切换开销小,只需要切换少量的寄存器和栈。
3、并发性:进程之间并发度低,因为切换成本高;线程之间并发度高,可以在一个进程内并发执行多个线程。
4、系统开销:创建和销毁进程的系统开销大;创建和销毁线程的开销相对较小。
习题二:操作系统的存储管理简述操作系统中常见的存储管理方式及其特点。
答案:常见的存储管理方式有:1、连续分配:包括单一连续分配和分区分配(固定分区和动态分区)。
单一连续分配方式简单,但只能用于单用户、单任务的操作系统;固定分区分配缺乏灵活性,会产生内部碎片;动态分区分配会产生外部碎片。
2、分页存储管理:将内存空间划分为固定大小的页框,将进程空间划分为相同大小的页面,通过页表进行映射。
优点是没有外部碎片,缺点是存在一定的内部碎片。
3、分段存储管理:按照程序的逻辑分段,每个段有不同的长度和属性。
便于实现信息共享和保护,但会产生外部碎片。
4、段页式存储管理:结合了分段和分页的优点,先分段,再分页。
既便于实现分段共享和保护,又解决了外部碎片问题,但增加了系统开销。
习题三:死锁的产生条件及解决方法阐述死锁产生的必要条件,并说明预防死锁和避免死锁的方法。
答案:死锁产生的必要条件有四个:1、互斥条件:资源在某一时间内只能被一个进程使用。
2、请求和保持条件:进程在持有部分资源的同时,又请求新的资源。
3、不剥夺条件:进程已获得的资源在未使用完之前,不能被其他进程强行剥夺。
操作系统概念习题答案
操作系统概念习题答案操作系统概念习题答案操作系统是计算机系统中非常重要的一个组成部分,它负责管理和控制计算机的硬件和软件资源,为用户提供一个方便、高效、安全的工作环境。
学习操作系统的过程中,习题是一个非常好的练习和巩固知识的方式。
下面将针对一些常见的操作系统概念习题给出详细的答案。
1. 什么是进程?答:进程是计算机中正在运行的程序的实例。
每个进程都有自己的地址空间、代码、数据和执行状态。
进程是操作系统进行资源分配和调度的基本单位。
2. 什么是线程?答:线程是进程中的一个执行单元。
一个进程可以有多个线程,它们共享进程的资源,如地址空间和文件描述符。
线程之间的切换比进程之间的切换更快,因此线程的并发性能更高。
3. 什么是调度算法?答:调度算法是操作系统用来决定哪个进程或线程应该被调度执行的一种策略。
常见的调度算法有先来先服务(FCFS)、最短作业优先(SJF)、时间片轮转等。
4. 什么是死锁?答:死锁是指在并发系统中,两个或多个进程因争夺资源而陷入无限等待的状态。
死锁的发生是由于进程之间的竞争和互斥访问共享资源的问题导致的。
5. 什么是虚拟内存?答:虚拟内存是一种操作系统的内存管理技术,它将物理内存和磁盘空间结合起来,为每个进程提供一个连续的、私有的地址空间。
虚拟内存可以使得每个进程都有足够的内存空间,并且能够更好地管理内存资源。
6. 什么是页面置换算法?答:页面置换算法是虚拟内存管理中用来选择哪些页面应该被置换出去以腾出空间给新的页面使用的一种策略。
常见的页面置换算法有最佳置换算法(OPT)、先进先出(FIFO)、最近最久未使用(LRU)等。
7. 什么是文件系统?答:文件系统是操作系统用来管理和组织文件的一种机制。
它提供了对文件的创建、读写、删除等操作,并且能够为文件分配磁盘空间、进行文件的索引和目录的管理。
8. 什么是设备驱动程序?答:设备驱动程序是操作系统中用来控制和管理硬件设备的软件模块。
它提供了对设备的访问接口,使得应用程序可以通过操作系统来操作硬件设备。
操作系统习题解答
操作系统习题解答部门: xxx时间: xxx整理范文,仅供参考,可下载自行编辑《操作系统教程》南邮正式版习题解答第三章进程管理与调度习题1、什么是多道程序设计?多道程序设计利用了系统与外围设备的并行工作能力,从而提高工作效率,具体表现在哪些方面?b5E2RGbCAP答:让多个计算问题同时装入一个计算机系统的主存储器并行执行,这种设计技术称“ 多道程序设计”,这种计算机系统称“多道程序设计系统” 或简称“多道系统”。
在多道程序设计的系统中,主存储器中同时存放了多个作业的程序。
为避免相互干扰,必须提供必要的手段使得在主存储器中的各道程序只能访问自己的区域。
p1EanqFDPw提高工作效率,具体表现在:•提高了处理器的利用率;充分利用外围设备资源:计算机系统配置多种外围设备,采用多道程序设计并行工作时,可以将使用不同设备的程序搭配在一起同时装入主存储器,使得系统中各外围设备经常处于忙碌状态,系统资源被充分利用; DXDiTa9E3d•发挥了处理器与外围设备以及外围设备之间的并行工作能力;从总体上说,采用多道程序设计技术后,可以有效地提高系统中资源的利用率,增加单位时间内的算题量,从而提高了吞吐率。
RTCrpUDGiT2、请描述进程的定义和属性。
答:进程是具有独立功能的程序关于某个数据集合上的一次运行活动,是系统进行资源分配、调度和保护的独立单位。
进程的属性有:结构性•共享性•动态性•独立性•制约性•并发性3、请描述进程与程序的区别及关系。
答:程序是静止的,进程是动态的。
进程包括程序和程序处理的对象<数据集),进程能得到程序处理的结果。
进程和程序并非一一对应的,一个程序运行在不同的数据集上就构成了不同的进程。
通常把进程分为“系统进程”和“用户进程”两大类,把完成操作系统功能的进程称为系统进程,而完成用户功能的进程则称为用户进程。
5PCzVD7HxA4、进程有哪三种基本状态?三种进程状态如何变化?答:通常,根据进程执行过程中不同时刻的状态,可归纳为三种基本状态:· 等待态:等待某个事件的完成;· 就绪态:等待系统分配处理器以便运行;· 运行态:占有处理器正在运行。
操作系统第三版习题答案
输入 程序 B 打印 程序 B 打印
CPU 时间
程序 A
程序 B
程序 A
50
100
130
(2) CPU 有空闲等待,它发生在 100ms∼130ms 时间段内,此时间段内程序 A 与程序 B
200
230
280
380
ms
都在进行 I/O 操作。 (3) 程序 A 无等待现象,程序 B 在 0ms∼50ms 时间段与 200ms∼230ms 时间段内有等待 现象。 3、设三道程序,按照 A、B、C 优先次序运行,其内部计算和 I/O 操作时间由图给出。 A B C C11=30ms C21=60ms C31=20ms | | | I12=40ms I22=30ms I32=40ms | | | C13=10ms C23=10ms C33=20ms 试画出按多道运行的时间关系图(忽略调度执行时间)。完成三道程序共花多少时间?比 单道程序节省了多少时间?若处理器调度程序每次运行程序的转换时间花 1ms,试画出 各程序状态转换的时间关系图。 解答:完成三道程序抢占式花费时间是 190 ms,非抢占花费时间是 180 ms,单道花费 时间是 260 ms,抢占式比单道节省时间为 70 ms。 单道程序运行时间:260ms A:30+40+10=80 ms B:60+30+10=100 ms C:20+40+20=80 ms 4、在单 CPU 和两台 I/O(I1 和 I2)设备的多道程序设计环境下,同时投入三个作业运行。 它们的执行轨迹如下: Job1:I2(30ms)、CPU(10ms)、I1(30ms)、CPU(10ms)、I2(20ms) Job2:I1(20ms)、CPU(20ms)、I2(40ms) Job3:CPU(30ms)、I1(20ms) 、CPU(10ms)、I1(10ms) 如果 CPU、I1 和 I2 都能并行工作,优先级从高到低为 Job1、Job2 和 Job3,优先级高 的作业可以抢占优先级低的作业的 CPU,但是不抢占 I1 和 I2。试求: (1)每个作业从投入到完成分别需要多少时间。 (2)从投入到完成 CPU 的利用率。 (3) I/O 设备的利用率。 答:(1)JOB1,JOB2,JOB3 从投入到完成分别所需时间为 110,90,110。 (2)每个作业从投入到完成 CPU 的利用率是 72.7%。 (3)I1 的利用率是 72.7%,I2 的利用率是 81.8%。 5、在单 CPU 和两台 I/O(I1 和 I2)设备的多道程序设计环境下,同时投入三个作业运行。 它们的执行轨迹如下: Job1:I2(30ms)、CPU(10ms)、I1(30ms)、CPU(10ms) Job2:I1(20ms)、CPU(20ms)、I2(40ms) Job3:CPU(30ms)、I1(20ms)
第1章操作系统概论课后习题解答-
7
第1章 操作系统概论课后习题解答
11.处理机管理有哪些主要功能?它们的主要任务 是什么? 【解答】略 12.内存管理有哪些主要功能?它们的主要任务是 什么? 【解答】略 13.设备管理有哪些主要功能?它们的主要任务是 什么? 【解答】 略
8
第1章 操作系统概论课后习题解答
14.文件管理有哪些主要功能?它们的主要任务是什 么? 【解答】略 15.操作系统提供了哪些人机接口? 【解答】略
3
第1章 操作系统概论课后习题解答
6.为什么要引入分时操作系统? 【解答】略 7.分时系统是怎样实现的? 【解答】在分时系统中,虽然若干用户通过各自的终端共享 一台主机,但是在操作系统的管理下,每个用户都感觉自己 在独占一台主机。分时系统采用的策略是:基于主机的高速 运行,分时为终端用户服务。即主机按一定次序轮流为各终 端用户服务,每个用户一次仅使用主机很短的一段时间(称 为时间片,毫秒级),在分得的时间片内若用户没有完成工 作则暂时中断,将处理机分配给下一个用户。虽然在一个用 户使用主机时其他用户处于等待状态,但是等待的时间很短, 用户感觉不到,从而每个用户的各次请求都能得到快速响应, 给每个用户的印象是:他独占一台计算机。
4
第1章 操作系统概论课后习题解答
8.实时操作系统应用在哪些场合?
【解答】实时系统应用于两个领域: (1)实时控制 当把计算机用于生产过程的控制,以形成以计算机为中心的控制系统时, 系统要求能实时采集现场数据,并对所采集的数据进行及时处理,进而 自动地控制相应的执行机构,使某些(个)参数(如温度、压力、方位 等)能按预定的规律变化。类似地,也可将计算机用于武器的控制,如 火炮的自动控制系统、飞机的自动驾驶系统,以及导弹的制导系统等。 通常把要求进行实时控制的系统称为实时控制系统。 (2)实时信息处理 通常,我们把要求对信息进行实时处理的系统,称为实时信息处理系统。 该系统由一台或多台主机通过通信线路连接成百上千个远程终端,计算 机接收从远程终端发来的服务请求,对数据进行检索和处理,并及时将 结果反馈给用户。典型的实时信息处理系统有:飞机订票系统、情报检 索系统。
操作系统原理与应用(第2版)清大版第2章习题参考答案
1、进程是程序在一个数据集合上运行的过程,它是系统进行资源分配和调度的一个独立单位。
在程序并发执行时已不再具有封闭性,而且产生了许多新的特性和新的活动规律。
程序这一静态概念已不足以描述程序的并发执行的特性。
为了适应这一新情况,引入了一个能反应程序并行执行特点的新概念——进程(process)。
有的系统也称为任务(task)。
2、进程:是程序的一次执行,是动态概念;一个进程可以同时包括多个程序;进程是暂时的,是动态地产生和消亡的。
程序:是一组有序的静态指令,是静态概念;一个程序可以是多个进程的一部分;程序可以作为资料长期保存。
3、能够看到。
进程控制块PCB表示进程的存在。
为进程的实体为:程序部分描述了进程所要完成的功能,它通常可以由若干个进程所共享。
数据部分包括程序运行时所需要的数据和工作区,它通常是各个进程专有的。
4、可再现性:程序重复执行时,必将获得相同的结果。
即对于程序A来说,第一次运行得到一结果,第二次运行时若中间有停顿,但最后的结果必将与第一次一样。
封闭性:程序一旦开始运行,其计算结果和系统内资源的状态不受外界因素的影响。
5、1)运行状态:进程正占用CPU,其程序正在CPU上执行。
处于这种状态的进程的个数不能大于CPU的数目。
在单CPU机制中,任何时刻处于运行状态的进程至多是一个。
2)就绪状态:进程已具备除CPU以外的一切运行条件,只要一分得CPU马上就可以运行(万事具备,只欠东风)。
在操作系统中,处于就绪状态的进程数目可以是多个。
为了便于管理,系统要将这多个处于就绪状态的进程组成队列,此队列称为就绪队列。
3)封锁状态:进程因等待某一事件的到来而暂时不能运行的状态。
此时,即使将CPU 分配给它,也不能运行,故也称为不可运行状态或挂起状态。
系统中处于这种状态的进程可以是多个。
同样,为了便于管理,系统要将它们组成队列,称为封锁队列。
封锁队列可以是一个,也可以按封锁原因形成多个封锁队列。
6、(1)1---分到CPU,2---时间片到,3---等待某一事件的发生,4---所等待事件已发生。
操作系统练习题+参考答案
操作系统练习题+参考答案一、单选题(共100题,每题1分,共100分)1、若系统中有5个并发进程涉及某个相同的变量A,则变量A的相关临界区由()个临界区构成。
A、1B、3C、5D、6正确答案:C2、在分页虚拟存储管理系统中,采用某些页面置换算法,会出现Belady 异常现象,即进程的缺页次数会随着分配给该进程的页面数量的增加而增加。
下列算法中,可能出现Belady现象的是()。
①LRU算法②FIFO 算法③OPT算法A、仅2B、仅1、2C、仅1、3D、仅2、3正确答案:A3、下列关于管道通信的叙述中,正确的是()。
A、一个管道可以实现双向数据传输B、管道的容量仅受磁盘容量大小的限制C、进程对管道进行读操作和写操作都可能被阻塞D、一个管道只能有一个读进程或一个写进程对其操作正确答案:C4、不属于基本操作系统的是()。
A、网络操作系统B、实时操作系统C、分时操作系统D、批处理操作系统正确答案:A5、采用SPOOLing技术的目的是()。
A、提高独占设备的利用率B、提高程序的运行速度C、提高主机的效率D、减轻用户的编程负担正确答案:A6、在()的控制下,计算机系统能及时处理由过程控制反馈的数据,并作出响应。
A、分时操作系统B、实时操作系统C、批处理操作系统D、多处理机操作系统正确答案:B7、在分页虚拟存储管理中,当发现要访问的页面不在主存时,则由硬件发出()。
A、输入输出中断B、时钟中断C、缺页中断D、越界中断正确答案:C8、()可以用来解决临界区问题。
A、时间片轮转算法B、银行家算法C、LRU算法D、Test正确答案:D9、可变分区存储管理系统中,若采用最佳适应分配算法,“空闲分区表”中的空闲区应该按()顺序排列。
A、地址从大到小B、大小从大到小C、地址从小到大D、大小从小到大正确答案:D10、进程从运行状态转换到阻塞状态可能是由于()。
A、现运行进程执行了signal操作B、现运行进程时间片用完C、现运行进程执行了wait操作D、进程调度程序的调度正确答案:C11、()不是进程的特征。
计算机操作系统(第四版)课后习题答案第二章
第二章之迟辟智美创作1. 什么是前趋图?为什么要引入前趋图?答:前趋图(Precedence Graph)是一个有向无循环图,记为DAG(Directed Acyclic Graph),用于描述进程之间执行的前后关系.2. 画出下面四条诧句的前趋图:S1=a:=x+y;S2=b:=z+1;S3=c:=a-b;S4=w:=c+1;答:其前趋图为:3. 为什么法式并发执行会发生间断性特征?法式在并发执行时,由于它们共享系统资源,以及为完成同一项任务而相互合作,致使在这些并发执行的进程之间,形成了相互制约的关系,从而也就使得进程在执行期间呈现间断性.4. 法式并发执行时为什么会失去封闭性和可再现性?因为法式并发执行时,是多个法式共享系统中的各种资源,因而这些资源的状态是由多个法式来改变,致使法式的运行失去了封闭性.而法式一旦失去了封闭性也会招致其再失去可再现性.5. 在把持系统中为什么要引入进程概念?它会发生什么样的影响?为了使法式在多道法式环境下能并发执行,并能对并发执行的法式加以控制和描述,从而在把持系统中引入了进程概念. 影响: 使法式的并发执行得以实行.6. 试从静态性,并发性和自力性上比力进程和法式?a. 静态性是进程最基本的特性,可暗示为由创立而发生,由调度而执行,因得不到资源而暂停执行,以及由裁撤而消亡,因而进程由一定的生命期;而法式只是一组有序指令的集合,是静态实体.b. 并发性是进程的重要特征,同时也是OS的重要特征.引入进程的目的正是为了使其法式能和其它建立了进程的法式并发执行,而法式自己是不能并发执行的. c. 自力性是指进程实体是一个能自力运行的基本单元,同时也是系统中自力获得资源和自力调度的基本单元.而对未建立任何进程的法式,都不能作为一个自力的单元来运行.7. 试说明PCB的作用?为什么说PCB是进程存在的唯一标识表记标帜?a. PCB是进程实体的一部份,是把持系统中最重要的记录型数据结构.PCB中记录了把持系统所需的用于描述进程情况及控制进程运行所需的全部信息.因而它的作用是使一个在多道法式环境下不能自力运行的法式(含数据),成为一个能自力运行的基本单元,一个能和其它进程并发执行的进程.b. 在进程的整个生命周期中,系统总是通过其PCB对进程进行控制,系统是根据进程的PCB而不是任何另外什么而感知到该进程的存在的,所以说,PCB是进程存在的唯一标识表记标帜.11.试说明进程在三个基本状态之间转换的典范原因. 答:(1)就绪状态→执行状态:进程分配到CPU 资源(2)执行状态→就绪状态:时间片用完(3)执行状态→阻塞状态:I/O请求(4)阻塞状态→就绪状态:I/O完成12.为什么要引入挂起状态?该状态有哪些性质?答:引入挂起状态处于五种分歧的需要: 终端用户需要,父进程需要,把持系统需要,对调需要和负荷调节需要.处于挂起状态的进程不能接收处置机调度. 10.在进行进程切换时,所要保管的处置机状态信息有哪些?答:进行进程切换时,所要保管的处置机状态信息有:(1)进程以后暂存信息(2)下一指令地址信息(3)进程状态信息(4)过程和系统调用参数及调用地址信息.13.在进行进程切换时,所要保管的处置机状态信息有哪些?答:进行进程切换时,所要保管的处置机状态信息有:(1)进程以后暂存信息(2)下一指令地址信息(3)进程状态信息(4)过程和系统调用参数及调用地址信息.14.试说明引起进程创立的主要事件. 答:引起进程创立的主要事件有:用户登录、作业调度、提供服务、应用请求.15.试说明引起进程被裁撤的主要事件. 答:引起进程被裁撤的主要事件有:正常结束、异常结束(越界毛病、呵护错、非法指令、特权指令错、运行超时、等候超时、算术运算错、I/O 故障)、外界干预(把持员或把持系统干预、父进程请求、父进程终止). 16.在创立一个进程时所要完成的主要工作是什么?答:(1)OS 发现请求创立新进程事件后,调用进程创立原语Creat();(2)申请空白PCB;(3)为新进程分配资源;(4)初始化进程控制块;(5)将新进程拔出就绪队列.17.在裁撤一个进程时所要完成的主要工作是什么?答:(1)根据被终止进程标识符,从PCB 集中检索出进程PCB,读出该进程状态. (2)若被终止进程处于执行状态,立即终止该进程的执行,臵调度标识表记标帜真,指示该进程被终止后重新调度. (3)若该进程还有子进程,应将所有子孙进程终止,以防它们成为不成控进程. (4)将被终止进程拥有的全部资源,归还给父进程,或归还给系统. (5)将被终止进程PCB 从所在队列或列表中移出,等候其它法式搜集信息.18.试说明引起进程阻塞或被唤醒的主要事件是什么?答:a. 请求系统服务;b. 启动某种把持;c. 新数据尚未达到;d. 无新工作可做.19. 为什么要在OS中引入线程?在OS中引入进程的目的,是为了使多个法式能并发执行,以提高资源利用率和系统吞吐量.在OS中再引入线程,则是为了减少法式在并发执行时所付出的时空开销,使OS具有更好的并发性.20.试说明线程具有哪些属性?答:(1)轻型实体(2)自力调度和分派的基本单元(3)可并发执行(4)共享进程资源.21. 试从调度性,并发性,拥有资源及系统开销方面对进程和线程进行比力. a. 调度性.在传统的把持系统中,拥有资源的基本单元和自力调度、分派的基本单元都是进程,在引入线程的OS中,则把线程作为调度和分派的基本单元,而把进程作为资源拥有的基本单元; b. 并发性.在引入线程的OS中,不单进程之间可以并发执行,而且在一个进程中的多个线程之间,亦可并发执行,因而使OS具有更好的并发性; c. 拥有资源.无论是传统的把持系统,还是引入了线程的把持系统,进程始终是拥有资源的一个基本单元,而线程除拥有一点在运行时必不成少的资源外,自己基本不拥有系统资源,但它可以访问其隶属进程的资源;d. 开销.由于创立或裁撤进程时,系统都要为之分配和回收资源,如内存空间等,进程切换时所要保管和设置的现场信息也要明显地多于线程,因此,把持系统在创立、裁撤和切换进程时所付出的开销将显著地年夜于线程.。
操作系统概论试题及答案
操作系统概论试题及答案一、选择题1. 操作系统是一个特殊的软件,它的主要功能是:A. 控制计算机硬件B. 提供用户界面C. 管理和调度资源D. 实现应用程序答案:C. 管理和调度资源2. 下列哪个不是操作系统的特征?A. 并发性B. 共享性C. 虚拟性D. 局限性答案:D. 局限性3. 操作系统有哪些组成部分?A. 内核B. ShellC. 文件系统D. 所有选项都正确答案:D. 所有选项都正确4. 进程和线程的区别是:A. 进程是资源的基本单位,线程是CPU调度的基本单位B. 进程是单线程的,线程是多线程的C. 进程之间有独立的地址空间,线程共享地址空间D. 进程和线程没有区别答案:C. 进程之间有独立的地址空间,线程共享地址空间5. 下列哪个不是进程状态?A. 运行B. 就绪C. 等待D. 暂停答案:D. 暂停二、问答题1. 请简要说明操作系统的作用及重要性。
操作系统是计算机系统中非常重要的一个组成部分。
它主要的作用是对计算机硬件进行管理和调度,为其他应用程序提供一个良好的运行环境。
操作系统的重要性体现在以下几个方面:首先,操作系统可以有效地管理和调度计算机的资源,包括CPU、内存、硬盘等。
通过合理地分配资源,并按照一定的优先级进行调度,可以提高计算机的利用率,使系统运行更加高效稳定。
其次,操作系统可以提供用户界面,使用户能够方便地与计算机进行交互。
无论是命令行界面还是图形界面,操作系统都能够以一种直观友好的方式呈现给用户,使得用户能够轻松地操作计算机并运行应用程序。
最后,操作系统还能够提供一些基本的服务和功能,如文件系统、网络功能、安全性控制等。
这些功能可以为应用程序提供良好的支持,使得应用程序能够更高效地运行,并且保护用户的数据和隐私安全。
总之,操作系统是计算机系统中必不可少的一个环节,它能够提供资源管理、用户界面和各种基本功能,保证计算机系统的正常运行。
2. 请简述进程和线程的概念,并说明它们之间的关系。
操作系统概念课后习题答案
操作系统概念课后习题答案操作系统概念课后习题答案第一章:引论⒈操作系统的功能和目标是什么?答:操作系统的功能包括了进程管理、内存管理、文件系统管理、设备管理等。
操作系统的目标是提高计算机系统的资源利用率,提供简单易用的用户界面,保证计算机系统的安全和稳定性。
⒉什么是并发性?并行性?有什么区别?答:并发性是指计算机系统中存在多个独立的任务同时执行的能力。
并行性是指系统中同时执行多个任务的能力。
并行性强调多个任务的同时进行,而并发性强调任务的独立性。
⒊什么是中断?有什么作用?答:中断是指计算机执行过程中出现的一种特殊事件,用于打断正在执行的程序,转而执行中断处理程序。
中断的作用是能够及时响应输入/输出设备的请求以及处理发生的异常情况。
⒋什么是多道程序设计?答:多道程序设计是指将多个程序加载到内存中,并按照一定的调度算法来分时共享处理器和其他资源。
⒌什么是虚拟内存?答:虚拟内存是计算机系统通过借助硬盘空间来扩展内存空间的一种技术。
它将部分物理内存空间映射到磁盘上,使得程序可以访问比实际物理内存更大的地质空间。
第二章:进程管理⒈什么是进程?什么是线程?答:进程是指在操作系统中运行的程序的实例,它包括了程序代码、数据和执行状态等。
线程是进程中的一个执行单元,一个进程可以包含多个线程,它们共享进程的资源。
⒉进程的状态有哪些?请描述每个状态的含义。
答:进程的状态包括了就绪状态、运行状态、阻塞状态。
就绪状态表示进程已经具备运行的条件,等待分配处理器资源。
运行状态表示进程正在执行。
阻塞状态表示进程由于某种原因暂时无法继续执行。
⒊进程调度算法有哪些?请简要描述每个算法的特点。
答:常见的进程调度算法有先来先服务(FCFS)、短作业优先(SJF)、优先级调度、时间片轮转等。
FCFS按照进程的到达顺序进行调度,适用于长作业。
SJF按照进程的执行时间进行调度,适用于短作业。
优先级调度根据进程的优先级进行调度。
时间片轮转将处理器时间分成若干个时间片,每个进程获得一个时间片。
操作系统答案(B)
题号
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
答案
C
A
C
B
C
D
D
B
D
C
B
C
A
A
D
C
C
B
D
C
二、判断题(共10题,每题1分,共10分)
题号
1
2
3
4
5
6
7
8
9
10
答案
错
错
对
错
对
错
对
错
对
错
三、填空题(共10题,每题2分, 共20分)
1.并发共享虚拟2资源不足进程推进顺序非法3.并行交叉访问RAID14. PCB
3.答: 分页和分段都采用离散分配方式,但两者有显著的差别。 〔1) 页是信息的物理单位.分页是系统的需要.是为了提高内存的利用率;段是信息的逻 辑单位.目的在于更好地满足用户的需要 (2)页的大小固定。由系统确定.一个系统只能有一种大小的页面:段的长度不固定。决 定于用户的程序。 (3)分页的作业地址空间是——维的.单一的线性地址空间;分段的作业地址空间是一维 的。—个地址包括段号和段内地址。
2.答:常见的数据传送方式有程序直接控制方式、中断控制方式、直接内存访问方式(DMA)和通道控制方式。 程序直接控制方式管理简单.价格低廉,但要使主机等待I/O没备。而设备和CPU、设备和设备只能串行工作; 中断控制方式在某种程度上使CPU摆脱了等待I/O设备的空转现象.主机和外设可以并行工作,提高了主机的利用率,但由于中断次数多.每次中断都要作现场保护和恢复工作.系统开销较大,仍然要占用较多的cPu时间,而且快速的I/O设备要求中断响应要足够快。否则会造成数据丢失; DMA方式和通道控制方式都较好地解决了上述问题。从而大大减少了CPU的负担。DMA方式与通道控制方式相比.在灵活性和功能方而.仍存在—定的局限性.DMA方式要求CPU执行设备驱动程序启动设备,给出存放数据的内存起始地址以及操作方式和传送字节长度等,而且一个DMA控制器只能控制—个设备。
操作系统解答题练习
操作系统解答题练习1. 进程管理题目:简述进程的三个基本状态,并说明它们之间的转换条件。
答案:进程的三个基本状态为:运行状态、就绪状态和阻塞状态。
•运行状态:进程正在CPU上执行。
•就绪状态:进程已获得除CPU之外的所有资源,一旦得到CPU即可执行。
•阻塞状态:进程因等待某些事件(如输入输出操作)而暂时不能执行。
状态之间的转换条件如下:•运行到就绪:进程时间片用完或主动让出CPU。
•运行到阻塞:进程等待某些事件,如I/O操作。
•就绪到运行:进程获得CPU。
•阻塞到就绪:进程等待的事件发生。
2. 内存管理题目:解释分页和分段内存管理方案的优缺点。
答案:•分页:–优点:简化内存管理,实现虚拟内存。
–缺点:内部碎片。
•分段:–优点:提供逻辑上的内存,有利于保护。
–缺点:段数量限制,可能导致外部碎片。
3. 文件系统题目:简述FAT32和NTFS文件系统的区别。
答案:•FAT32:–适用范围:主要用于U盘、移动硬盘等可移动存储设备。
–优点:实现简单,兼容性好。
–缺点:文件夹数量限制,安全性较低。
•NTFS:–适用范围:主要用于Windows操作系统的分区。
–优点:支持更大的文件和文件夹数量,安全性高。
–缺点:兼容性相对较差,分区格式化速度较慢。
4. 设备管理题目:简述I/O请求的两种方式:中断驱动和直接内存访问(DMA)。
答案:•中断驱动:I/O设备在完成数据传输后,向CPU发送中断信号,CPU 响应中断,进行数据处理。
•DMA:I/O设备直接访问内存,完成数据传输,减少了CPU的参与,提高了系统性能。
5. 进程同步与互斥题目:解释信号量(Semaphore)和互斥锁(Mutex)的区别。
答案:•信号量:–用于控制对共享资源的访问,可以是二进制信号量或计数信号量。
–提供了P(等待)和V(信号)操作,实现进程同步与互斥。
•互斥锁:–用于实现进程间的互斥访问共享资源。
–只有两种状态:锁定和非锁定。
–通过锁定和解锁操作实现进程间的同步。
操作系统概述习题及解答
一、操作系统概述习题及解答:1.硬件将处理机划分为两种状态,即管态和目态,这样做给操作系统设计带来什么好处?答:便于设计安全可靠的操作系统。
管态和目态是计算机硬件为保护操作系统免受用户程序的干扰和破坏而引入的两种状态。
通常操作系统在管态下运行,可以执行所有机器指令;而用户程序在目态下运行,只能执行非特权指令。
如果用户程序企图在目态下执行特权指令,将会引起保护性中断,由操作系统终止该程序的执行,从而保护了操作系统。
2.何谓特权指令? 举例说明之。
如果允许用户进程执行特权指令会带来什么后果?答:在现代计算机中,一般都提供一些专门供操作系统使用的特殊指令,这些指令只能在管态执行,称为特权指令。
这些指令包括:停机指令、置PSW指令、中断操作指令(开中断、关中断、屏蔽中断)、输入输出指令等。
用户程序不能执行这些特权指令。
如果允许用户程序执行特权指令,有可能干扰操作系统的正常运行,甚至有可能使整个系统崩溃。
3.中断向量在机器中的存储位置是由硬件确定的,还是由软件确定的?答:中断向量在机器中的存放位置是由硬件确定的。
例如,在INTEL 80x86 CPU 中,内存空间0x00000—0x003ff为中断向量空间。
4.中断向量的内容是由操作系统程序确定的,还是由用户程序确定的?答:由操作系统程序确定的。
向量的内容包括中断处理程序的入口地址和程序状态字(中断处理程序运行环境),中断处理程序是由操作系统装入内存的,操作系统将根据装入的实际地址和该中断处理程序的运行环境来填写中断向量。
5.中断向量内的处理机状态位应当标明是管态还是目态? 为什么?答:应当标明是管态。
这样才能保证中断发生后进入操作系统规定的中断处理程序。
6.中断与程序并发之间的关系是什么?答:中断是程序并发的前提条件。
如果没有中断,操作系统不能获得系统控制权,无法按调度算法对处机进行重新分配,一个程序将一直运行到结束而不会被打断。
7.说明“栈”和“堆”的差别.答:栈是一块按后进先出规则访问的存储区域,用来实现中断嵌套和子程序调用的参数和返回断点。
操作系统概论-06
操作系统概论-06【6】并发进程6.1进程的并发性1进程的顺序性和并发性:进程的顺序性是指进程在顺序处理器上执⾏是严格按照顺序运⾏当⼀个进程独占处理器顺序执⾏时具有封闭性和可再现性若系统中存在⼀组可同时执⾏的进程则称为改组进程具有并发性并把可同时执⾏的进程称为并发进程2 并发进程相互之间可能是⽆关的也可能是有交往的:如果⼀个进程的执⾏不影响其他进程的执⾏则这些并发进程相互之间⽆关的如果⼀个进程的执⾏影响进程的执⾏则这些并发进程之间是有交往的6.2与时间有关的错误1并发进程的执⾏速度受⾃⾝原因以及进程调度策略的影响:⼀个进程运⾏会被中断且断点不是固定的⼀个劲被中断后哪个进程可以运⾏被中断的进程什么时候占⽤处理器是进程调度策略有关的因此进程的执⾏速度是不能由⾃⼰决定的2并发进程交替使⽤共享资源时会出现跟时间有关的错误:由于共享资源的原因加上⼆进制并发进程的随机性⼀个进程对另⼀个进程的影响是不可预测的,造成不正确的因素与进程占⽤处理器的时间执⾏的速度以及外界的影响有关的因此被称为与时间有关的错误3 分析与时间有关的错误:⼀个飞机航班系统有n个售票处每个售票区通过终端访问系统公共数据区嘉定⼯作数据区的⼀些单元Aj(j=1,2,...)分别存放 X⽉X⽇X次航班的余票数设P1 P22.。
Pn 表⽰各个售票区的处理进程 R1 R2 Rn 表⽰进程执⾏占⽤⼯作单位当售票处有⼈买票进程如下⼯作 process Pi(i=1,2...) begin 按照旅客要求找到AjRi = Aj ; if Ri >= 1 then; begin Ri :=Ri-1:Aj =Ri 输出⼀张票 endElse :输出票已经售完End; 这⾥如果有两个都需要同⼀个班次的票然后同时购买但是票只有⼀张⽽进程并发执⾏可能会把⼀张票买个⼏个⽤户,核⼼问题就是多个进程同时访问⼀个变量产⽣的问题。
6.3 临界值PV操作1临界值的定义:并发进程中与共享变量有关的进程断称为临界值2相关临界值区管理要求 1⼀次到多⼀个进程能进⼊临界区当有进程在临界区执⾏时其他想想进⼊临界区的进程必须等待2不能让⼀个进程⽆限制的在临界区执⾏即任何⼀个进⼊临界区的进程必须在有限的时间内退出临界区3不能强迫⼀个进程⽆限的等待进⼊它的临界区即有进程退出临界区应让⼀个等待进⼊临界区的进程进⼊它的临界区执⾏。
操作系统概论复习题及答案
操作系统概论复习题及答案一、单选题(共100题,每题1分,共100分)1、操作系统的作用是A、控制和管理系统资源的使用B、便于进行目标管理C、把源程序编译为目标程序D、实现软硬件的虚拟化正确答案:A2、可变分区存储管理中,不需要对空闲区表进行排序的主存分配算法是A、最优适应B、最先适应C、最小碎片D、最坏适应正确答案:B3、在操作系统中,要对甲、乙两个并发进程进行同步的原因是A、进程具有结构性B、进程具有动态性C、甲、乙两个进程需要访问临界资源D、甲、乙两进程必须在有限的时闻内完成正确答案:C4、程序状态字(PSW)需要包含许多内容,一般包含A、目态/管态、等待/计算、中断码、中断屏蔽位、指令地址、控制/计算B、条件码、目态/管态、等待/计算、中断码、中断屏蔽位、指令地址C、控制/计算、条件码、目态/管态、指令地址、中断码、中断屏蔽位D、指令地址、控制/计算、条件码、目态/管态、等待/计算、中断码正确答案:B5、有交互的并发进程之闯A、不可能共享某些资源B、不可能共享信号量C、一定共享信号量D、一定共享某些资源正确答案:D6、如果一组并发进程是无关的,则它们A、不能同时执行B、没有共享变量C、各自包含的程序都不同D、执行的相对速度是固定的正确答案:B7、虚拟存储器是A、容量扩大了的主存B、可提高计算机运算速度的设备C、实际上不存在的存储器D、可以容纳总和超过主存容量的多个作业同时运行的一个地址空间正确答案:D8、使用SPOOLING系统的目的是为了A、提高操作系统使用效率B、提高内存使用效率C、提高I/O设备使用效率D、提高CPU使用效率正确答案:C9、操作系统负责管理计算机的A、程序B、资源C、进程D、作业正确答案:B10、计算机系统的层次结构的组成部分包括A、支撑软件、系统软件、计算机硬件、操作人员、应用软件B、操作人员、应用软件、接口软件、支撑软件、系统软件C、应用软件、接口软件、支撑软件、系统软件、计算机硬件D、接口软件、支撑软件、系统软件、计算机硬件、操作人员正确答案:A11、在单道系统中,一个程序顺序执行时其执行结果A、受外界发生的事件影响B、由占用处理器的时间决定C、取决于程序本身D、与执行速度有关正确答案:C12、如果按照文件的用途对文件分类,其中的类别之一是A、库文件B、档案文件C、只读文件D、执行文件正确答案:A13、以磁盘文件系统为例,文件存储的几种常用方式中,连续分配的缺点是A、读操作性能不好B、随着时间推移会形成很多“空洞”C、打开文件时需要频繁读取硬盘D、可以充分利用每个簇正确答案:B14、在程序装入时对目标程序中的指令和数据地址的修改过程称为A、重定位B、编译C、链接D、加载正确答案:A15、关于操作系统,下列说法正确的是A、操作系统是一种系统软件B、操作系统是一种通用软件C、操作系统是一种应用软件D、操作系统是一种工具软件正确答案:A16、根据使用的角度,外围设备可以分为独占设备和可共享设备,下列属于可共享设备的是A、磁盘机B、输入机C、输入输出处理机D、打印机正确答案:A17、假定某采用页式存储管理的系统中,主存的容量为1MB,被分成256块,块号为0,1,2,……,255。
自考_操作系统概论真题第6章 并发进程
自考_操作系统概论真题第6章并发进程自考_操作系统概论真题第6章并发进程一、单选题18.并发进程执行的相对速度是()a.由进程的程序结构决定的c.在进程被创建时确定的b、 D.由过程本身控制。
与进程调度策略相关19.并发进程执行时可能会出现“与时间有关的错误”,引起这种错误的原因是()a.进程执行的顺序性c.程序的结构b、访问共享变量D所需的处理器时间20.进程间采用信箱通信方式时,可调用send原语把信件投放到()a.发送者信箱b、收件人邮箱c.指定的工作区d.指定的pcb16.在并发进程的描述中,错误的语句是()a、进程的执行速度不能由进程自己来控制b、进程的执行速度与进程占用处理器的时间有关。
C.进程的执行速度与是否发生中断事件有关。
D.任意两个并发进程之间存在相互制约关系17、用v操作唤醒一个等待进程时,被唤醒进程的状态应该是()a、运行b、就绪c、收容d、执行18.当系统发生死锁时,必须同时保持四个必要条件。
资源的顺序分配策略可能会破坏它中的()a、互斥条件b、占有且等待条件c、不可抢占资源条件d、循环等待条件19、有n个进程竞争必须互斥使用的共享资源时,若某进程调用p操作后成为第一个等待使对于资源用户,此时的信号量值是()a,n-1b,0C,1D,-120、有n个进程竞争某共享资源,系统允许每次最多m个进程同时使用该资源,若用pv操在管理期间,信号量的变化范围为()a、[M,(M+n)]B、[n,(M+n)]C、[(M-n)、M]d、[(M-n)、n]18.若进程用信件来传递信息,那么发送信息者的进程名应()a.存放在信件中c、作为接收原语的参数b.作为send原语的参数d.存放在信箱说明中19.无法防止死锁的资源分配策略是()。
A.剥夺分配方法C.静态分配方法b.按序分配方式d.互斥使用分配方式20.该系统有五种特定类型的资源,由三个进程共享。
为了确保系统的安全性,每个进程应用的资源量应该是有限的源数不超过()...a.1个c.3个b、 2 D.418.进程间采用信箱方式进行通信时,在信件中应指出()a.接收者名c.信件名19.对资源使用顺序分配策略可以(a)防止死锁和(c)检测死锁b.避免死锁d.解除死锁b.发送者名d.信箱名20.在使用PV操作管理关键区域时,如果n个进程正在等待进入关键区域,则此时的信号量值为()A.nb.lc、 0d。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
“操作系统概论”习题解答之并发进程第7章习题解答1.什么叫并发进程?答:在多道程序设计系统中,作为单个作业可以同时执行,而每一个作业又需要有多个进程的协作来完成。
因此,系统会同时存在着许多进程,在单处理器的情况下,这些进程轮流的占用处理器,即一个进程的工作没有全部完成之前,另一个进程就开始工作,我们说这些可同时执行的进程具有并发性,并且把可同时执行的进程称为“并发进程”。
2.临界区是怎样定义?对临界区的管理应符合哪些要求?答:并发进程中与共享变量有关的程序段称为“临界区”。
对若干个并发进程共享某一变量的相关临界区得管理有三点要求:①一次至多一个进程能够进入临界区,当有进程在临界区执行时,其他想进入临界区执行的进程必须等待。
②不能让一个进程无限制的在临界区执行,即任何一个进入临界区的进程必须有限的时间内退出临界区。
③不能强迫一个进程无限期等待键入它的临界区,即有进程退出临界区时应让一个等待进入临界区的进程进入它的临界区执行。
3.采用PV操作作为同步机构时,假定与某共享变量相关的信号量S的值可在[-1,l]之间,问S的初值是哪个值?当S=-1,S=0,S=l时它们各自的物理含义是什么?答:S的初值是 1.S=-l,表示有一个进程在等待进入临界区执行。
S=0,表示已有一个进程在临界区执行,这时若有进程想进入临界区则必须等待。
S=l,表示无进程在临界区执行,若有进程想进入临界区则可以立即进入。
4.A、B两个火车站之间是单轨连接的,现有许多列车同时到A站,须经A再到达B站,列车出B站后又可分路行驶(如图7-2)为保证行车安全,请你当调度时,你将如何调度列车?请你用PV操作为工具设计一个能实现你的调度方案的自动调度系统。
答:当A、B两站之间无列车停驶时,可让到达A站的一列车进人A、B站之间行驶。
当A石站之间有列车在行驶时,则到达A站者必须在站外等待。
当有列车到达B站后,让等在A站外的一列车进入。
用一个信号量S来控制到达A站的列车能否进入单轨道行驶,S的初始值为l.列车到达A站后,先执行P(S),若无列车在A、B站之间行驶,则执行P(S)后立即进人单轨道行驶,到达B站后,执行V(S),可释放一个等待进入的列车进入行驶。
若A、B站之间已有列车在行驶,则执行P(S)后就等待,直到行驶者到了B站执行V(S)后释放一个欲进入者。
5.今有三个进程R、M、P,它们共享一个缓冲区。
R负责从输入设备读信息,每次读出一个记录并把它存放在缓冲区中:M在缓冲区加工读入的记录;P把加工后的记录打印输出。
输入的记录经加工输出后,缓冲区中又可存放下一个记录。
请用P、V操作为同步机构写出他们并发执行时能正确工作的程序。
答:三个进程共用一个缓冲区,他们必须同步工作,可定义三个信号量:S1:表示是否可把读人的记录放到缓冲区,初始值为1.S2:表示是否可对缓冲区中的记录加工,初始值为0.S3:表示记录是否加工好,可以输出,初始值也为0.三个进程可如下设计:beginS1,S2,S3:semaphore;S1:=l;S2:=S3:=0;cobeginprocess RbeginL1:读记录;P(S1);记录存入缓冲区;V(S2);goto L1;end;process MbeginL2:P(S2);加工记录;V(S3);goto L2;end;process PbeginL3:P(S3);输出加工后的记录;V(S1);goto L3;end;coend;end.6.现有4个进程R1,R2,W1,W2,它们共享可以存放一个数的缓冲器B.进程R1每次把从键盘上投入的一个数存放到缓冲器B中,供进程W1打印输出;进程R2每次从磁盘上读一个数放到缓冲器B中,供进程W2打印输出。
当一个进程把数据存放到缓冲器后,在该数还没有被打印输出之前不准任何进程再向缓冲器中存数。
在缓冲器中还没有存入一个新的数之前不允许任何进程加快从缓冲区中取出打印是怎样才能使这四个进程在并发执行是协调的工作?答:这四个进程实际上是两个生产者 R1,R2和两个消费者 W1,W2.各自生成不同的产品中各自的消费对象去消费,他们共享一个的缓冲器。
由于缓冲器只能存放一个数,所以,R1和R2在存放数时必须互斥。
而R1和W1、R2和W2之间存在同步。
为了协调它们的工作可定义三个信号量:S:表示能否把数存人缓冲器B,初始值为1.S1:表示R1是否已向缓冲器存入从键盘上读入的一个数,初始值为0.S2:表示R2是否已向缓冲器存入从磁盘上读入的一个数,初始值为0.beginS,S1,S2:semaphore;S:=1;S1:=S2:=0;cobeginprocess R1xl :integerbeginL1:从键盘读一个数;x1:=读入的数;P(S);B:=xl;V(S1);goto L1;end;process R2x2:integer;beginL2:从磁盘读一数;x2:=读入的数;P(S);B:=x2;V(S2);goto L2;end;process W1y:integer;beginL3:P(S1);y:=B;V(S);打印y中的数;goto L3;end;process W2z:integerbeginL4:P(S2);z:=B;V(S);打印z中的数;goto L4;end;coend;end.7.两个并发进程的程序如下:beginN:integer;N:=3;cobeginprocess AbeginL1:N:=N+5;goto L1;end;process BbeginL2:print(N);N:=0;goto L2;end;coend;end.若process A先执行了三个循环后,process A和 process B又并发执行了一个循环,写出可能出现的打印值。
请用PV操作实现同步,使两并发进程能正确执行。
答:可能的值是 18或 23.这是因为 process A执行三个循环后,N=18,之后 A和 B 并发执行,可能先执行A中的N:=N+5,再执行B中的print(N);这样就会得到23,也可能先执行B中的pint(N);这就会得到18.可以利用P、V操作实现同步:beginN:integer;S:semphore;S:=l;N:=3;cobeginprocess AbeginL1:P(S);N:=N+5;V(S);gotO L1;end;process BbeginL2:P(S);print(N);N:=0;V(S);goto L2;end;coend;end.8.通信机制中设置哪些基本通信原语?它们的功能是什么?答:系统提供两个与信箱通信有关的通信原语:send原语(发送)和 receive原语(接收)。
send(B,M)原语把信件M送人到信箱B中,receive(B,X)原语从信箱B中取出一封信存放到指定的地址X中。
9.什么叫死锁?什么原因会引起死锁?答:若系统中存在一组进程(二个或多个进程),他们中的每一个进程都占用某种资源而又都在等待其中另一个进程所占用的资源,这种等待永远不能结束,就说系统出现“死锁”。
进程死锁的起因是系统提供的资源数比要求使用资源的进程数少,或者是若干个个进程要求资源的总数大于系统能提供的资源数。
这时,进程间就会出现竞争资源的现象,如果对进程竞争的资源管理和分配不当就会引起死锁。
死锁的出现是与资源分配策略和并发进程的执行速度有关。
10.有哪些策略可防止和避兔死锁?答:防止死锁的策略有:静态分配、按序分配、剥夺式分配。
银行家算法可以避免死锁。
11.某系统有输入机和打印机各一台,今有两个进程都要同时使用他们,采用PV操作实现请求使用和归还释放后,还会产生死锁吗?若否,说明理由;若会产生死锁则给出一种防止死锁的方法。
答:如果 PV操作设计不当,仍会产生死锁。
假如用 S1 S2分别代表输入机和打印机能否被使用的信号量,由于资源是共享的,所以必须互斥使用,因而它们的初始值都为l.如果用如下方式实现请求使用和归还释放:process QIbeginP(S1);使用输入机;P(S2);使用打印机;V(S2);V(S1);end;process Q2beginP(S2);使用打印机;P(S1);使用输入机;V(S2);V(S1);end;那么就会出现Q1得到输入机而 Q2得到打印机,双方在不释放已经有的资源的情况下又去申请新的资源,就会造成死锁。
可以采用为资源编序号的方法,要求按序申请,如下:process Q1beginP(S1);使用输入机;P(S2);使用打印机;V(S2);V(S1);end;process Q2beginP(S1);使用输入机;P(S2);使用打印机;V(S2);V(S1);end.12.某一系统分配资源的策略是:当进程提出申请资源时,只要系统有资源中是分配给它,系统无资源时让它登台。
任一进程总是先释放以占有的资源后在申请新的资源,且每次申请一个资源,系统中的进程得到资源后总能在有限时间内归还。
证明该系统不会发生死锁。
答:任一进程P申请资源时出现两种情况:情况一,立即得到满足,此时不会成为等待状态,也就不存在引起死锁的条件。
情况二,得不到满足,处于等待资源状态。
此时,资源一定被另一进程 Q占有。
进程 Q 执行时若不在申请资源,则必在有限时间里归还资源,于是 P不会永远等待。
如果进程 Q 执行时还要申请资源,按题意,它一定先释放占有的资源,于是 P也不会永远等待。
所以,任一进程申请资源总能在有限时间得到资源,因而不会产生死锁。