操作系统的一些概念题(3)
操作系统的一些概念题(3)
答案均取自网络或是书本的理解整理(百度知道,百度百科,《操作系统》(张尧学),CSDN,百度题库,百度文库等)
存储管理
存储管理的主要功能是什么?
(课本答案)
存储管理的主要功能包括以下几点:
(1)在硬件的支持下完成统一管理内存和外存之间数据和程序段自动交换的虚拟存储。
(2)将多个虚存的一维线性空间或多维线性空间变换到内存的唯一的一维物理线性地址。
(3)控制内外存之间的数据传输
(4)实现内存的分配和回收
(5)实现内存信息的共享与保护
(百度百科)
虚拟内存技术不仅仅可让我们可以使用更多的内存,它还提供了以下功能:
1、寻址空间
操作系统让系统看上去有比实际内存大得多的内存空间。虚拟内存可以是系统中实际物理空间的许多倍。每个进程运行在其独立的虚拟地址空间中
这些虚拟空间相互之间都完全隔离开来,所以进程间不会互相影响。同时,硬件虚拟内存机构可以将内存的某些区域设置成不可写。这样可以保护代码与数据不会受恶意程序的干扰
2、内存映射
内存映射技术可以将映象文件和数据文件直接映射到进程的地址空间。在内存映射中,文件的内容被直接连接到进程虚拟地址空间上
3、物理内存分配
内存管理子系统允许系统中每个运行的进程公平地共享系统中的物理内存
4、共享虚拟内存
尽管虚拟内存允许进程有其独立的虚拟地址空间,但有时也需要在进程之间共享内存
例如有可能系统中有几个进程同时运行BASH命令外壳程序。为了避免在每个进程的虚拟内存空间内都存在BASH程序的拷贝,较好的解决办法是系统物理内存中只存在一份BASH的拷贝并在多个进程间共享
什么是虚拟存储器?其特点是什么?
虚拟存储器是计算机系统内存管理的一种技术。它使得应用程序认为它拥有连续的可用的内存(一个连续完整的地址空间),而实际上,它通常是被分隔成多个物理内存碎片,还有部分暂时存储在外部磁盘存储器上,在需要时进行数据交换
特点有以下4点:
1.虚拟扩充:不是物理上而是逻辑上扩充了内存容量
2.部分装入:每个作业不是全部一次性地装入内存,而是只装入一部分
3.离散分配:不必占用连续的内存空间,而是“见缝插针”
4.多次对换:所需的全部程序和数据要分成多次调入内存
实现地址重定位的方法有那些?
实现地址重定位的方法有两种:静态地址重定位和动态地址重定位
静态地址重定位是在虚空间程序执行之前由装配程序完成地址映射工作。静态重定位的优点是不需要硬件支持,但是用静态地址重定位方法进行地址变换无法实现虚拟存储器
静态重定位的另一个缺点是必须占用连续的内存空间和难以做到程序和数据的共享
动态地址重定位是在程序执行过程中,在CPU访问内存之前由硬件地址变换机构将要访问的程序或数据地址转换成内存地址
动态地址重定位的主要优点有:
①可以对内存进行非连续分配
②动态重定位提供了实现虚拟存储器的基础
③动态重定位有利于程序段的共享
常用的内存信息保护方法有哪几种?各自的特点是什么?
常用的内存保护方法有硬件法、软件法和软硬件结合保护法三种
上下界保护法是一种常用的硬件保护法
上下界存储保护技术要求为每个进程设置对上下界寄存器,上下界寄存器中装有被保护程序和数据段的起始地址和终止地址,在程序执行过程中,在对内存进行访问操作时首先进行访问地址合法性检查,即检查经过重定位之后的内存地址是否在上、下界寄存器所规定的范围之内,若在规定的范围之内,则访问是合法的;否则是非法的,并产生访问越界中断
保护键法也是一种常用的软件存储保护法
保护键法为每—个被保护存储块分配一个单独的保护键,在程序状态字中则设置相应的保护键开关字段,对不同的进程赋予不同的开关代码以和被保护的存储块中的保护键匹配,保护键可以设置成对读写同时保护的或只对读写进行单项保护的,如果开关字段与保护键匹配或存储块未受到保护,则访问该存储块是允许的,否则将产生访问出错中
另外一种常用的硬软件内存保护方式是:界限存储器与CPU的用户态,核心态相结合的保护方式
在这种保护方式下,用户态进程只能访问那些在界限寄存器所规定范围内的内存部分,而核心态进程则可以访问整个内存地址空间
动态分区式管理的常用内存分配算法有哪几种?各自的优缺点?
动态分区式管理的常用内存分配算法有最先适应法、最佳适应法和最坏适应法
优缺点比较:
①从搜索速度上看最先适应法最佳,最佳适应法和最坏适应法都要求把不同大小的空闲区按大小进行排队
②从回收过程来看,最先适应法也是最佳,因为最佳适应法和最坏适应法都必须重新调整空闲区的位置
③最佳适应法找到的空闲区是最佳的,但是会造成内存碎片较多,影响了内存利用率,而最坏适应法的内存碎片最少,但是对内存的请求较多的进程有可能分配失败
总之,三种算法各有所长,针对不同的请求队列,它们的效率和功能是不一样的
覆盖和交换的概念?两者的区别是什么?
简单来说,交换是指将主存里的数据与虚拟内存中需要放入主存中的数据进行交换,这种方法使得主存中的数据仍然存在,而覆盖是指直接将虚拟内存中的数据直接放入主存,也就是说主存之前的数据将不存在了
与覆盖技术相比,交换不要求程序员给出程序段之间的覆盖结构,而且,交换主要是在进程或作业之间进行,而覆盖则主要在同一个作业或同一个进程内进行,另外,覆盖只能覆盖那些与覆盖程序段无关的程序段
什么是页式管理?静态页式管理可以实现虚存吗?
页式管理就是把各进程的虚拟空间划分为若干长度相等的页,把指令按页面大小划分后存放在内存中执行或只在内存中存放那些经常被执行或即将被执行的页,而那些不被经常执行以及在近期内不可能被执行的页则存放于外存中,按一定规则调入的一种内存管理方式
静态页式管理不能实现虚存,这是因为静态页式管理要求进程或作业在执行前全部被装入内存,作业或进程的大小仍受内存可用页面数的限制
请求管页式管理是什么?
请求页式管理是动态页式内存管理的一种,它在作业或进程开始执行之前,不把作业或进程的程序段和数据段一次性的全部装入内存,而只装入被认为是经常反复执行和调用的工作区部分,其他部分则在执行过程中动态装入
请求页式管理的调入方式是:当需要执行某条指令而又发现它不在内存时,或当执行某条指令需要访问其他数据或指令时,而这些指令和数据又不在内存中,从而发生缺页中断,系统将外存中相应的页调入内存
请求页式管理中哪几种常用的页面置换算法?优缺点各自是什么?
比较常用的页面置换算法有:
(1) 随机淘汰算法,即随机地选择某个用户页面并将其换出
(2) 轮转法,轮转法循回换出内存可用区内一个可以被换出的页,无论该页是刚被换进或已经换进内存很长时间
(3) 先进先出法,FIFO算法选择在内存驻留时间最长的一页将其淘汰
(4) 最近最久未使用页面置换算法,该算法的基本思想是:当需要淘汰某一页时,选择离当前时间最近的一段时间内最久没有使用过的页面先淘汰
该算法很难实现,比较常用的近似算法:最不经常使用页面淘汰算法LFU、最近没有使用页面淘汰算法NUR
(5) 理想型淘汰算法,该算法淘汰在访问串中将来再也不出现的或是在离当前最远的位置上出现的页面
段式管理是什么?和页式管理的区别是什么?
段式管理,是指把一个程序分成若干个段进行存储,每个段都是一个逻辑实体,程序员需要知道并使用它
它的产生是与程序的模块化直接有关的,段式管理是通过段表进行的,它包括段号或段名、段起点、装入位、段的长度等。此外还需要主存占用区域表、主存可用区域表
段式管理和页式管理的主要区别有:
**(1) **页式管理中源程序进行编译链接时是将主程序、子程序、数据区等按照线性空间的一维地址顺序排列起来。段式管理则是将程序按照内容或过程(函数)关系分成段,每段拥有自己的名字。一个用户作业或进程所包含的段对应于一个二维线性虚拟空间,也就是一个二维虚拟存储器
**(2) **同动态页式管理一样,段式管理也提供了内外存统一管理的虚存实现。与页式管理不同的是:段式虚存每次交换的是一段有意义的信息,而不是像页式虚存管理那样只交换固定大小的页,从而需要多次的缺页中断才能把所需信息完整地调入内存
**(3) **在段式管理中,段长可根据需要动态增长。这对那些需要不断增加或改变新数据或子程序的段来说,将是非常有好处的
**(4) **段式管理便于对具有完整逻辑功能的信息段进行共享
**(5) **段式管理便于进行动态链接,而页式管理进行动态链接的过程非常复杂
为什么要提出段页式管理?与段式管理和页式管理的区别在哪?
因为段式管理和页式管理各有所长
段式管理为用户提供了一个二维的虚拟地址空间,反映了程序的逻辑结构,有利于段的动态增长以及共享和内存保护等,这极大地方便了用户
而分页系统则有效地克服了碎片,提高了存储器的利用效率
从存储管理的目的来讲,主要是方便用户的程序设计和提高内存的利用率。所以人们提出了将段式管理和页式管理结合起来让其互相取长补短的段页式管理
段页式管理与段式和页式管理相比,其访问时间较长,因此,执行效率低
段页式管理的优缺点?改进办法?
优点:可以分别编写和编译,可以针对不同类型的段采取不同的保护,可以按段为单位来进行共享,包括通过动态链接进行代码共享
缺点:对内存中指令或数据进行存取时,至少需要对内存进行三次以上的访问
第一次是由段表地址寄存器取段表始址后访问段表,由此取出对应段的页表在内存中的地址。第二次则是访问页表得到所要访问的指令或数据的物理地址。只有在访问了段表和页表之后,第三次才能访问真正需要访问的物理单元。显然。这将大大降低CPU执行指令的速度
改进办法是设置快速联想寄存器
在快速联想寄存器中.存放当前最常用的段号s,页号p和对应的内存页面地址与其他控制项。当需要访问内存空间某一单元时,可在通过段表、页表进行内存地址查找的同时,根据快速联想寄存器查找其段号和页号
如果所要访问的段或页的地址在快速联想寄存器中,则系统不再访问内存中的段表、页表而直接把快速联想寄存器中的值与页内相对地址d拼接起来得到内存地址
什么是局部性原理?什么是抖动?
局部性原理是指在几乎所有程序的执行过程中,在一段时间内,CPU总是集中地访问程序中的某一个部分而不是对程序的所有部分具有平均的访问概率
抖动是指当给进程分配的内存小于所要求的工作区时,由于内存外存之间交换频繁,访问外存的时间和输入输出处理时间大大增加,反而造成CPU因等待数据而空转,使得整个系统性能大大下降
在物理系统中,为防止抖动的产生,在进行淘汰或替换时,一般总是把缺页进程锁住,不让其换出,从而防止抖动发生
防止抖动发生的另一个办法是设置较大的内存工作区
文件系统
什么是文件?什么是文件系统?文件系统有哪些功能?
在计算机系统中,文件被解释为一组赋名的相关字符流的集合,或者是相关纪录的集合
文件系统是操作系统中与管理文件有关的软件和数据
文件系统的功能:为用户建立文件、撤销、读写、修改和复制文件,以及完成对文件的按名存取和进行存取控制。
文件的一般分类标准?可以分成哪几类?
文件一般按性质、用途、组织形式、文件中的信息流向或文件的保护级别等分类
按性质和用途可分为系统文件、库文件和用户文件
按文件的组织形式可分为普通文件、目录文件和特殊文件
按文件中的信息流向可分为输入文件、输出文件和输入/输出文件
按文件的保护级别可分为只读文件、读写文件、可执行文件和不保护文件
什么是文件逻辑结构?什么是记录?
文件的逻辑结构:指一个文件在用户面前所呈现的形式,逻辑结构有两种形式:
①记录式文件(有结构式文件)
②字符流式文件(无结构式文件),也称流式文件
记录是一个具有特定意义的信息单位,由该纪录在文件中的逻辑地址(相对位置)与记录名所对应的一组关键字、属性及其属性值所组成
常用的文件存储设备的管理方法有哪些?优缺点?
文件存储设备的管理实质上是一个空闲块的组织和管理问题
有3种不同的空闲块管理方法,即空闲文件目录、空闲块链和位示图
空闲文件目录管理方法就是把文件存储设备中的空闲块的块号统一放在一个称为空闲文件目录的物理块中,其中空闲文件目录的每个表项对应一个由多个空闲块构成的空闲区。
该方法实现简单,适于连续文件结构的文件存储区的分配与回收。但是由于回收时不进行合并,所以使用该方法容易产生大量的小块空闲区
空闲块链法把文件存储设备上的所有空闲块链接在一起,从链头分配空闲块,把回收的空闲块插入到链尾。该方法不占用额外的空间,但实现复杂
位示图法是从内存中划出若干字节,每个比特位对应一个物理块的使用情况。如果该位为0表示对应的块是空闲的,为1表示对应的物理块已分配出去。位示图法在查找空闲块时无需启动外设,但要占用内存空间
什么是文件目录?文件目录里包含了哪些信息?
一个文件的文件名和对该文件实施控制管理的说明信息成为该文件的说明信息,又称为该文件的文件控制块(FCB),所有的FCB组织在一起,就构成了文件目录,即文件控制块的有序集合
文件目录中包含文件名、与文件名相对应的文件内部标识以及文件信息在文件存储设备上的第一个物理块的地址等信息
另外还可能包含关于文件的逻辑结构、物理结构、存取控制信息和管理等信息
文件存取控制方式有哪几种?优缺点?
文件存取控制方式一般有存取控制矩阵、存取控制表、口令和密码术4种方式。
存取控制矩阵方式以一个二维矩阵来进行存取控制。而且矩阵的一维是所有的用户。另一维是所有的文件。对应的矩阵元素则是用户对文件的存取控制权。存取控制矩阵的方法在概念上比较简单,但是当用户和文件较多时,存取控制矩阵将变得非常庞大,从而时间和空间的开销都很大
存取控制表以文件为单位,把用户按某种关系划分为若干组,同时规定每组的存取限制。这样所有用户组对文件权限的集合就形成了该文件的存取控制表。存取控制表方法占用空间较小,搜索效率也较高,但要对用户分组,引入了额外的开销。
口令方式有两种,一种是当用户进入系统时,为建立终端进程时获得系统使用权的口令,另一种方式是,每个用户在创建文件时,为每个创建的文件设置一个口令,且将其置于文件说明中
当任一用户想使用该文件时,都必须首先提供口令。口令方式比较简单,占用的内存单元以及验证口令所费时间都非常少,不过,相对来说,口令方式保密性能比较差
密码术方式在用户创建源文件并写入存储设备时对文件进行编码加密,在读出文件时对文件进行译码解密,加密方式具有保密性强的优点
但是,由于加密解密工作要耗费大量的处理时间,因此,加密技术是以牺牲系统开销为代价的
设备管理
设备管理的目标和功能是什么?
设备管理的目标是:
(1)选择和分配输入/输出设备以便进行数据传输操作
(2)控制输入/输出设备和CPU(或内存)之间交换数据
(3)为用户提供一个友好的透明接口
(4)提高设备和设备之间、CPU和设备之间,以及进程和进程之间的并行操作,以使操作系统获得最佳效率
设备管理的功能是:
(1)提供和进程管理系统的接口
(2)进行设备分配
(3)实现设备和设备、设备和CPU等之间的并行操作
(4)进行缓冲区管理
数据传送控制方式有哪几种?优缺点?
数据传送控制方式有程序直接控制方式、中断控制方式、DMA方式和通道方式4种
程序直接控制方式就是由用户进程来直接控制内存或CPU和外围设备之间的数据传送
它的优点是控制简单,也不需要多少硬件支持
它的缺点是CPU和外围设备只能串行工作,设备之间只能串行工作,无法发现和处理由于设备或其他硬件所产生的错误
中断控制方式是利用向CPU发送中断的方式控制外围设备和CPU之间的数据传送
它的优点是大大提高了CPU的利用率且能支持多道程序和设备的并行操作
它的缺点是由于数据缓冲寄存器比较小,如果中断次数较多,仍然占用了大量CPU时间,在外围设备较多时,由于中断次数的急剧增加,可能造成CPU无法响应中断而出现中断丢失的现象,如果外围设备速度比较快,可能会出现CPU来不及从数据缓冲寄存器中取走数据而丢失数据的情况
DMA方式是在外围设备和内存之间开辟直接的数据交换通路进行数据传送
它的优点是除了在数据块传送开始时需要CPU的启动指令,在整个数据块传送结束时需要发中断通知CPU进行中断处理之外,不需要CPU的频繁干涉
它的缺点是在外围设备越来越 多的情况下,多个DMA控制器的同时使用,会引起内存地址的冲突并使得控制过程进一步复杂化
通道方式是使用通道来控制内存或CPU和外围设备之间的数据传送。通道是一个独立与CPU的专管输入/输出控制的机构,它控制设备与内存直接进行数据交换。它有自己的通道指令,这些指令受CPU启动,并在操作结束时向CPU发中断信号
该方式的优点是进一步减轻了CPU的工作负担,增加了计算机系统的并行工作程度
缺点是增加了额外的硬件,造价昂贵
什么是通道?
通道是一种通过执行通道程序管理I/O操作的控制器,它使主机(CPU和内存)与I/O操作之间达到更高的并行shu程度,由于它的任务是管理实现输入/输出操作,提供一种传送通道,所以将这种部件称作通道
CPU把数据传输功能下放给通道,这样,通道与CPU分时使用内存,就可以实现CPU与外设的并行工作。在采用通道方式的指令系统中,除了供CPU编程使用的机器指令系统外,还设置另外供通道专用的一组通道指令,用通道指令编制通道程序,存入存储器
当需要进行I/O操作时,CPU只需启动通道,然后可以继续执行自身程序,通道则执行通道程序,管理与实现I/O操作。整个系统分为二级管理,一级是CPU对通道的管理,二级是通道对设备控制的管理
什么是中断?什么是中断处理?什么是中断响应?
中断是指计算机在执行期间,系统内发生任何非寻常的或非预期的急需处理事件,使得CPU暂时中断当前正在执行的程序而转去执行相应的事件处理程序,待处理完毕后又返回原来被中断处继续执行的过程
CPU转去执行相应的事件处理程序的过程称为中断处理
CPU收到中断请求后转到相应的事件处理程序称为中断响应
什么是关中断?什么是开中断?什么是中断屏蔽?
把CPU内部的处理机状态字PSW的中断允许位清除从而不允许CPU响应中断叫做关中断
设置CPU内部的处理机状态字PSW的中断允许位从而允许CPU响应中断叫做开中断
中断屏蔽是指在中断请求产生之后,系统用软件方式有选择地封锁部分中断而允许其余部分的中断仍能得到响应
什么是陷阱?什么是软中断?中断,陷阱和软中断之间的异同有哪些?
陷阱指处理机和内存内部产生的中断,它包括程序运算引起的各种错误,如地址非法、校验错、页面失效,存取访问控制错、从用户态到核心态的切换等都是陷阱的例子
软中断是通信进程之间用来模拟硬中断的一种信号通信方式
中断和陷阱的主要区别:
1 、陷阱通常由处理机正在执行的现行指令引起,而中断则是由与现行指令无关的中断源引起的
2 、陷阱处理程序提供的服务为当前进程所用,而中断处理程序提供的服务则不是为了当前进程的
3 、CPU 在执行完一条指令之后,下一条指令开始之前响应中断,而在一条指令执行中也可以响应陷阱
4 、在有的系统中,陷入处理程序被规定在各自的进程上下文中执行,而中断处理程序则在系统上下文中执行
什么是缓冲?为什么要引入缓冲?
缓冲即是使用专用硬件缓冲器或在内存中划出一个区域用来暂时存放输入输出数据的器件
引入缓冲是为了匹配外设和CPU之间的处理速度,减少中断次数和CPU的中断处理时间,同时解决DMA或通道方式时的数据传输瓶颈问题
用来设备分配的数据结构有哪些?之间的关系是什么?
在进行设备分配时所需要的数据结构有:
①设备控制表DCT――系统为每个设备配置一张设备控制表,用于记录本设备的情况,如设备类型,设备标识号、设备状态。设备队列、控制器表
②控制器控制表COCT――系统为每个控制器设备一张用于记录本控制器情况的控制器控制表
③系统设备表 SDT――记录系统中全部设备的情况,每个设备占一个表目,包括设备类型、设备标识符、设备控制表,设备驱动程序入口等
在配有通道,控制器系统的设备管理中,还要有通道控制表、CHCT,用来记录通道的特性、状态及其他管理信息
系统设备表中有对应的设备控制表的指针,设备控制表中有与该设备相连的控制器的控制表的指针,控制器控制表中有与该控制器相连的通道的通道控制表
也就是说,从系统设备表可以找到该设备的设备控制表,然后找到相连的控制器控制表,最后找到相连的通道的通道控制表
什么是I/O控制?
I/O控制是指从用户进程的输入输出请求开始,给用户进程分配设备和启动有关设备进行I/O操作,并在I/O操作完成之后响应中断,直至善后处理为止的整个系统控制过程
I/O控制可用哪几种方式实现?各有什么优缺点?
1,作为请求I/О操作的进程实现,能很快占据处理机但要求系统和I/О操作的进程有良好的实时性
2,作为当前进程的一部分实现,不要求系统具有高的实时性,但I/0控制过程要由当前进程负责
3,由专门的系统级I/О进程完成,增加了一个额外的进程开销,但用户不用关心I/О控制过程
设备驱动程序是什么?为什么要有设备驱动程序?用户进程怎么使用设备驱动程序?
设备驱动程序是驱动外部物理设备和相应DMA控制器或I/O控制器等器件,使之可以直接和内存进行I/O操作的子程序的集合。它们负责设置相应设备有关寄存器的值,启动设备进行I/O操作,指定操作的类型和数据流向等
设备驱动程序屏蔽了直接对硬件操作的细节,为编程者提供操纵设备的友好接口
用户进程通过调用设备驱动程序提供的接口来使用设备驱动程序
关于Linux和Windows系统下的进程与内存管理和文件系统就没有写出了,主要是没有实际使用Linux,有空补上