操作系统内存管理复习过程

合集下载

操作系统复习提纲

操作系统复习提纲

条件(不忙)队 列
共享数据
进入队列

… 一组操作过程 初始化代码
14
27/06/2011
进程通信

指进程间的信息交换。 分为: 低级通信(进程的同步和互斥) 高级通信:是用户直接利用操作系统所提供 的一组 通讯原语,实现高效地传送大量数据的一种通讯方式。
高级进程通信方式有三大类: 共享存储器系统 消息传递系统 管道(Pipe)通信
调用进程创建原语Creat( 新进程: (1)申请空白PCB。

)按下述步骤创建一个
(2)为新进程分配资源。为新进程的程序和数据以及用户栈 分配必要的内存空间。 (3)初始化进程控制块。 ①初始化标识信息。 ②初始化处理机状态信息。使程序计数器指向程序的入 口地址,使栈指针指向栈顶; ③初始化处理机控制信息:进程的状态、优先级。 (4)将新进程插入就绪队列。
11
27/06/2011
3、进程的阻塞与唤醒 4、进程的挂起与激活
进程同步
1 什么是进程同步 所谓同步,就是并发进程在一些关键点上可能需要互相等 待或互通消息,这样一种相互制约的等待与互通消息称为 进程的同步
12
27/06/2011
2、同步机制应遵循的规则
(1) 空闲让进。当无进程处于临界区时,应允许一个请求 进入临界区的进程立即进入自己的临界区,以有效地利 用临界资源。 (2) 忙则等待。当已有进程进入临界区时,其他试图进入 临界区的进程必须等待,以保证对临界资源的互斥访问。 (3)有限等待。对要求访问临界资源的进程,应保证在有限 时间内能进入自己的临界区,以免陷入“死等”状态。 (4)让权等待。当进程不能进入自己的临界区时,应立即 释放处理机。以免进程陷入“忙等”

计算机操作系统第四章存储器管理复习资料

计算机操作系统第四章存储器管理复习资料

第四章存储器管理第一部分教材习题(P159)15、在具有快表的段页式存储管理方式中,如何实现地址变换?答:在段页式系统中,为了便于实现地址变换,须配置一个段表寄存器,其中存放段表始址和段长TL。

进行地址变换时,首先利用段号S,将它与段长TL进行比较。

若S<TL,表示未越界,利用段表始址和段号来求出该段所对应的段表项在段表中的位置,从中得到该段的页表始址,并利用逻辑地址中的段内页号P来获得对应页的页表项位置,从中读出该页所在的物理块号b,再利用块号b和页内地址来构成物理地址。

在段页式系统中,为了获得一条指令或数据,须三次访问内存。

第一次访问内存中的段表,从中取得页表始址;第二次访问内存中的页表,从中取出该页所在的物理块号,并将该块号与页内地址一起形成指令或数据的物理地址;第三次访问才是真正从第二次访问所得的地址中,取出指令或数据。

显然,这使访问内存的次数增加了近两倍。

为了提高执行速度,在地址变换机构中增设一个高速缓冲寄存器。

每次访问它时,都须同时利用段号和页号去检索高速缓存,若找到匹配的表项,便可从中得到相应页的物理块号,用来与页内地址一起形成物理地址;若未找到匹配表项,则仍须再三次访问内存。

19、虚拟存储器有哪些特征?其中最本质的特征是什么?答:虚拟存储器有以下特征:多次性:一个作业被分成多次调入内存运行,亦即在作业运行时没有必要将其全部装入,只需将当前要运行的那部分程序和数据装入内存即可;以后每当要运行到尚未调入的那部分程序时,再将它调入。

多次性是虚拟存储器最重要的特征,任何其他的存储器管理方式都不具有这一特征。

因此,认为虚拟存储器是具有多次性特征的存储器系统。

对换性:允许在作业的运行过程中进行换进、换出,也即,在进程运行期间,允许将那些暂不使用的程序和数据,从内存调至外存的对换区(换出),待以后需要时再将它们从外存调至内存(换进);甚至还允许将暂不运行的进程调至外存,待它们重又具备运行条件时再调入内存。

操作系统复习存储器管理

操作系统复习存储器管理

第一章 存储器管理4.1 存储器的层次结构—存储器应容量大,便宜,速度跟上处理器4.1.1 多级存储器结构通常有三层,细分为六层,如图4-1, 越往上,速度越快,容量越小,价格越贵; 寄存器和主存又称可执行存储器,进程可直接用指令访问,辅存只能用I/O 访问;4.1.2 主存储器与寄存器1.主存储器---内存,保存进程运行时的程序和数据;CPU与外围设备交换的信息一般也依托于主存储器地址空间;为缓和访存速度远低于CPU 执行指令的速度,在计算机系统中引入了寄存器和高速缓存;2.寄存器---与CPU 协调工作,用于加速存储器的访问速度,如用寄存器存放操作数,或用地址寄存器加快地址转换速度等;4.1.3 高速缓存和磁盘缓存1.高速缓存---根据程序执行的局部性原理将主存中一些经常访问的信息程序、数据、指令等存放在高速缓存中,减少访问主存储器的次数,可大幅度提高程序执行速度;2.磁盘缓存---将频繁使用的一部分磁盘数据和信息,暂时存放在磁盘缓存中,可减少访问磁盘的次数;它依托于固定磁盘,提供对主存储器存储空间的扩充,即利用主存中的存储空间,来暂存从磁盘中读/写入的信息;4.2 程序的装入和链接多道程序运行,需先创建进程;而创建进程第一步是将程序和数据装入内存;将源程序变为可在内存中执行的程序,通常都要经过以下几个步骤:编译---若干个目标模块;链接---链接目标模块和库函数,形成装入模块;装入---图 4-2 对用户程序的处理步骤寄存器高速缓存主存磁盘缓存磁盘可移动存储介质CPU 寄存器主存辅存第一步第二步第三步内存4.2.1 程序的装入——无需连接的单目标模块装入理解装入方式1. 绝对装入方式Absolute Loading Mode ---只适用单道程序环境如果知道程序的内存位置,编译将产生绝对地址的目标代码,按照绝对地址将程序和数据装入内存;由于程序的逻辑地址与实际内存地址完全相同,故不须对程序和数据的地址进行修改;绝对地址:可在编译时给出或由程序员直接赋予;若由程序员直接给出,不利于程序或数据修改,因此,通常是在程序中采用符号地址,然后在编译或汇编时转换为绝对地址;2. 可重定位装入方式Relocation Loading Mode ---适于多道程序环境多道程序环境下,编译程序不能预知目标模块在内存的位置;目标模块的起始地址是0,其它地址也都是相对于0计算的;此时应采用可重定位装入方式,根据内存情况,将模块装入到内存的适当位置,如图4-3 作业装入内存时的情况 ;3.动态运行时装入方式Dynamic Run-time Loading ---适于多道程序环境可重定位装入方式并不允许程序运行时在内存中移动位置;但是,在运行过程中它在内存中的位置可能经常要改变,此时就应采用动态运行时装入方式;动态运行时的装入程序,在把装入模块装入内存后,并不立即把装入模块中的相对地址转换为绝对地址,而是把这种地址转换推迟到程序真正执行时才进行;因此,装入内存后的所有地址都仍是相对地址;问题:程序装入内存后修改地址的时机是什么4.3 连续分配方式4.3.3 动态分区分配——根据进程需要动态分配内存1. 分区分配中的数据结构1 空闲分区表—用若干表目记录每个空闲分区的分区序号、分区始址及分区的大小等数据项;2 空闲分区链--为实现对空闲分区的分配和链接,在每分区起始部分,设置前向指针,尾部则设置一后向指针;为检索方便,在分区前、后向指针中,重复设置状态位和分区大小表目;当分0内存空间区被分配后,把状态位由“0”改为“1”时,前、后向指针失去意义;图 4-5 空闲链结构2. 分区分配算法P1231首次适应算法first-fit —空闲分区链以地址递增次序链接 每次按分区链的次序从头查找,找到符合要求的第一个分区;2 循环首次适应算法—FF 算法的变种从上次找到的空闲分区位置开始循环查找,找到后,修改起始查找指针; 3 最佳适应算法—空闲分区按容量从小到大排序 把能满足要求的、最小的空闲分区分配给作业 4 最坏适应算法——空闲分区按容量从大到小排序 挑选最大的空闲区分给作业使用;5) 快速适应算法—根据容量大小设立多个空闲分区链表3. 分区分配操作1.分配内存请求分区u.size; 空闲分区m.size; m.size-u.size ≤size,说明多余部分太小, 不再切割,将整个分区分配给请求者;否则从该分区中划分一块请求大小的内存空间,余下部分仍留在空闲分区链;如图4-6 内存分配流程;2.回收内存1 回收区与插入点的前一空闲分区F1相邻:合并,修改F1大小;2 回收区与后一空闲分区F2相邻:合并,修改首地址和大小;3 回收区同时与前、后两个分区邻接:合并,修改F1大小,取消F2;4 回收区不邻接:新建表项,填写首地址和大小,并插入链表;如图前向指针N +20N 个字节可用后向指针N +2图 4-6 内存分配流程4.3.6 可重定位分区分配1.动态重定位的引入例:在内存中有四个互不邻接的小分区,容量分别为10KB 、30KB 、14KB 和26KB;若现有一作业要获得40KB 的内存空间,因连续空间不足作业无法装入;可采用的一种解决方法是:通过移动内存中作业的位置,以把原来多个分散的小分区拼接成一个大分区的方法,称为“拼接”或“紧凑;由于用户程序在内存中位置的变化,在每次“紧凑”后,都必须对移动了的程序或数据进行重定位;图 4-8 紧凑的示意4.3.7 对换即中级调度1. 对换Swapping 的引入(a ) 紧凑前(b ) 紧凑后“活动阻塞”进程占用内存空间;外存上的就绪作业不能进入内存运行;所谓“对换”,是指把内存中暂时不能运行的进程或者暂时不用的程序和数据,调出到外存上,以便腾出足够的内存空间;再把已具备运行条件的进程或所需要的程序和数据,调入内存;对换是提高内存利用率的有效措施;根据对换单位可分为:进程对换、页面对换和分段对换;为了能实现对换,系统应具备以下三方面功能:对换空间的管理、进程的换出与换入2. 进程的换出与换入1进程的换出选择阻塞且优先级最低的进程,将它的程序和数据传送到磁盘对换区上;回收该进程所占用的内存空间,并对该进程的进程控制块做相应的修改;2进程的换入找出“就绪” 但已换出到磁盘上时间最久的进程作为换入进程,将之换入,直至已无可换入的进程;4.4 基本分页存储管理方式前面的连续分配方案会形成许多“碎片”,“紧凑”方法可以解决碎片但开销大;是否允许进程离散装入 离散单位不同,称分页式存储和分段式存储;不具备对换功能称为“基本分页式”,支持虚拟存储器功能称为“请求基本分页式”;4.4.1 页面与页表1. 页面1 页面和物理块---将进程的逻辑地址空间分成若干个大小相等的片,称为页面,并为各页编号;相应地把内存空间分成与页面相同大小的若干个存储块,称为物理块,也同样编号;分配时,将进程中的页装入到物理块中,最后一页经常装不满一块而形成 “页内碎片”;2 页面大小---页面的大小应选择适中;页面太小,内存碎片减小,利用率高;但页表过长,占大量内存;页面较大,页表长度小;但页内碎片大;因此,页面的大小应选择得适中,且页面大小应是2的幂,通常为512 B~8 KB;2. 地址结构分页地址中的地址结构如下:31 12 11 0它含有两部分:页号P12~31位,最多有1M 页和页内位移量W0~11位,每页的大小4KB ; 对某特定机器,其地址结构是一定的;若给定一个逻辑地址空间中的地址为A,页面的大小为L,则页号P 和页内地址d 可按下式求得:MODL A d L A INT P ][=⎥⎦⎤⎢⎣⎡=3. 页表---实现从页号到物理块号的地址映射用户程序0 页1 页2 页3 页4 页5 页…n 页页表内存4.4.2 地址变换机构任务:将逻辑地址转换为物理地址;页内地址变换:因页内地址与物理地址一一对应, 可直接转换;页号变换:页表可实现从逻辑地址中页号到内存中物理块号的变换; 1.基本的地址变换机构a. 页表功能可由一组专门的寄存器实现原理;b. 页表大多驻留内存,系统中只设置一页表寄存器来存放页表在内存的始址和页表长度实际操作;c. 进程未执行时,页表始址和长度存放在PCB 中;执行时才将这两个数据装入页表寄存器中过程;图 4-12 分页系统的地址变换机构2. 具有快表的地址变换机构a. 仅用页表寄存器时,CPU 每存取一数据要两次访问内存页表-地址变换-数据;b. 为提高地址变换速度,可在地址变换机构中增设一具有并行查寻能力的特殊高速缓冲寄存器用以存放当前访问的那些页表项,称为“快表”;c. ->在CPU 给出逻辑地址,将页号P 送入快表 ->页号匹配,读物理块号后送物理地址寄存器->无匹配页号,再访问内存中页表,把从页表项中读出的物理块号送地址寄存器;同时,再将此页表项存入到快表中;->如快表已满,则OS 须找到一换出页表项换出; 为什么增加“快表”为了提高地址变换速度,可在地址变换机构中增设一个具有并行查寻能力的特殊高速缓冲寄存器,又称为“联想寄存器”Associative Memory,或称为“快表 “快表”有何缺点越界中断图 4-13 具有快表的地址变换机构4.5 基本分段存储管理方式4.5.1 分段存储管理方式的引入为什么引入推动内存从固定分配到动态分配直到分页存储,主要动力是内存利用率,而引入分段存储管理方式,主要是为了满足用户和程序员的下述一系列需要:1方便编程---把作业按逻辑关系划分为若干段,每段有自己的名字和长度,并从0开始编址;LOAD 1,A|<D>; STORE 1,B|<C>2 信息共享---段是信息的逻辑单位;为实现共享,存储管理应与用户程序分段的组织方式相适应;3 信息保护---对信息的逻辑单位进行保护,应分段管理;4 动态增长---分段存储能解决数据段使用过程中动态增长;5 动态链接---运行过程中动态调入以段为单位的目标程序;4.5.2 分段系统的基本原理1. 分段作业划分为若干段,如图4-16,每个段用段号来代替段名,地址空间连续;段的长度由逻辑信息长度决定,因而各段长度不等;其逻辑地址由段号段名和段内地址所组成,结构如下: 31 16 15 0该地址结构中,允许一个作业最多有64K 个段,每个段的最大长度为64KB;编译程序能自页表寄存器逻辑地址L 物理地址动根据源程序产生若干个段;2.段表,其中每段占一个表项,中;图4-16 利用段表实现地址映射3.分页和分段的主要区别1 页是信息的物理单位,分页是为提高内存的利用率,是为满足系统管理的需要;段则是信息的逻辑单位,分段是为了能更好地满足用户的需要;2 页的大小固定且分页由系统硬件实现;而段的长度不固定,通常由编译程序根据信息的性质来划分;3 分页的作业地址空间是一维的,程序只需一个地址记忆符;而分段的作业地址空间是二维的,程序员既需给出段名,又需给出段内地址;4.5.3 信息共享可重入代码纯代码:允许多个进程同时访问的代码;绝对不允许可重入代码在执行中改变,因此,不允许任何进程修改它;4.5.4 段页式存储管理方式1.基本原理---,,,4KB;作业空间内存空间子程序段数据段(a)段号(S)段内页号(P)页内地址(W)(b)主程序段图4-21 利用段表和页表实现地址映射4.6 虚拟存储器的基本概念前面各种存储器管理方式共同点:它们要求将一个作业全部装入内存后方能运行,于是出现了下面这样两种情况:1 有的作业很大,其所要求的内存空间超过了内存总容量,作业不能全部被装入内存,致使该作业无法运行;2 有大量作业要求运行,但由于内存容量不足以容纳所有这些作业,只能将少数作业装入内存让它们先运行,而将其它大量的作业留在外存上等待;4.5.1 虚拟存储器的引入1.常规存储器管理方式的特征1 一次性;将作业全部装入内存后方能运行,此外有许多作业在每次运行时,并非其全部程序和数据都要用到;一次性装入,造成了对内存空间的浪费;2 驻留性;作业装入内存后一直驻留,直至运行结束;尽管因故等待或很少运行,都仍将继续占用宝贵的内存资源;现在要研究的问题是:一次性及驻留性在程序运行时是否必需;2.局部性原理早在1968年, Denning.P就曾指出:1 程序执行时,除了少部分的转移和过程调用指令外,在大多数情况下仍是顺序执行的;2 过程调用将会使程序的执行轨迹由一部分区域转至另一部分区域,但经研究看出,过程调用的深度在大多数情况下都不超过5;3 程序中存在许多循环结构,这些虽然只由少数指令构成, 但是它们将多次执行;4 程序中还包括许多对数据结构的处理, 如对数组进行操作,它们往往都局限于很小的范围内;局限性主要表现在下述两个方面:1 时间局限性-由于循环操作的存在;如果程序中的指令或数据一旦执行,则不久以后可能再次访问;2 空间局限性-由于程序的顺序执行;程序在一段时间内所访问的地址,可能集中在一定的范围之内;3. 虚拟存储器定义---基于局部性原理程序运行前,仅须将要运行的少数页面或段装入内存便可启动,运行时,如果需要访问的页段尚未调入内存缺页或缺段,用OS提供请求调页段功能调入;如果此时内存已满,则还须再利用页段的置换功能,将内存中暂时不用的页段调至外存,腾出足够的内存空间后,再将要访问的页段调入;所谓虚拟存储器,是指具有请求调入功能和置换功能,能从逻辑上扩充内存容量的一种存储器系统;其逻辑容量由内存容量和外存容量之和所决定,其运行速度接近于内存,成本接近于外存;4.6.3 虚拟存储器的特征1)多次性---一个作业被分成多次调入内存运行,最初装入部分程序和数据,运行中需要时,再将其它部分调入;2)对换性---允许在作业的运行过程中进行换进、换出;换进和换出能有效地提高内存利用率;3)虚拟性---从逻辑上扩充内存容量,使用户所看到远大于实际内存容量;这是虚拟存储器最重要的特征和最重要的目标;4)离散性---是以上三个特性的基础,在内存分配时采用离散分配的方式;备注:虚拟性是以多次性和对换性为基础的,而多次性和对换性又必须建立在离散分配的基础上;4.7 请求分页存储管理方式4.6.1 请求分页中的硬件支持---页表、缺页中断和地址变换请求分页系统是在分页的基础上,增加了“请求调页”和“页面置换”功能,每次调入和换出基本单位都是长度固定的页,实现比请求分段简单;1.页表机制---将用户地址空间中的逻辑地址变换为内存空间中的物理地址,因只将部分调入内存,需增设若干项;在请求分页系统中的每个页表项如下所示:1 状态位P:该页是否已调入内存,供访问时参考;2 访问字段A:记录一段时间内本页被访问的频率,供选择换出页时参考;3 修改位M:页在调入内存后是否被修改过,供置换页面时参考;4 外存地址:指出该页在外存上的地址,即物理块号,供调入该页时参考;4.7.2 内存分配策略和分配算法1.最小物理块数的确定是指能保证进程正常运行所需的最小物理块数,当系统为进程分配的物理块数少于此值时,进程将无法运行;进程应获得的最少物理块数与计算机的硬件结构有关;对于某些简单的机器,所需的最少物理块数为2,分别用于存放指令和数据,间接寻址时至少要有三块;对于某些功能较强的机器,因其指令本身、源地址和目标地址都可能跨两个页面,至少要为每个进程分配6个物理块,以装入这些页面;2. 物理块的分配策略请求分页系统的两种内存分配策略:即固定和可变分配策略;两种置换策略:即全局置换和局部置换;可组合出以下三种策略;1 固定分配局部置换Fixed Allocation, Local Replacement--每进程分配一定数目的物理块,在整个运行期间都不再改变,换入换出都限于这些物理块;每个进程物理块难以确定,太多太少都不好2 可变分配全局置换Variable Allocation, Global Replacement --每进程分配一定数目的物理块,OS 保持一空闲物理块队列;进程缺页时,摘下一空闲块,并将该页装入;3 可变分配局部置换Variable Allocation, Local Replacemen --每进程分配一定数目的物理块;进程缺页时,只允许从该进程内存页中选出一页换出;若缺页中断频繁,再为该进程分配若干物理块,直至缺页率减少;若缺页率特低,则减少该进程的物理块数,应保证缺页率无明显增加;3. 物理块分配算法1 平均分配算法--将所有可供分配的物理块,平均分配给各个进程; 例如,有100个物理块,5个进程,每进程可分20个物理块;未考虑到各进程本身的大小;2 按比例分配算法--根据进程的大小按比例分配物理块;共n 个进程,每进程页面数为si,则页面数的总和为:设可用的物理块为m,每进程分到的物理块数为bi,有:3 考虑优先权的分配算法--为了照顾重要、紧迫的作业尽快完成,为它分配较多的空间;通常采取:把可供分配的物理块分成两部分:一部分按比例分给各进程;另一部分根据优先权分给各进程;有的系统是完全按优先权来分配;4.7.3 调页策略1. 何时调入页面1 预调页策略缺页前 :页面存放连续,用预测法一次调入多个相邻页,预测成功率仅为50%;2 请求调页策略缺页时:运行中,发现不在内存,立即请求,由OS 调入;2. 从何处调入页面请求分页系统中外存分为两部分:文件区和对换区;这样,当发生缺页请求时,系统应从何处将缺页调入内存:1 系统拥有足够的对换区,可以全部从对换区调入所需页面;在进程运行前,须将有关的文件拷贝到对换区;2 系统缺少足够的对换区,这时凡是不会被修改的文件,都直接从文件区调入,由于它们未被修改而不必换出;但对于可能被修改的部分,换出时调到对换区,以后需要时,再从对换区调入;3 UNIX 方式;凡是未运行过的页面,都应从文件区调入;曾运行过但已换出的页面,放在∑==ni iS S 1m SS b ii ⨯=对换区,下次应从对换区调入;4.8 页面置换算法当进程运行时,所访问的页面不在内存而需要将他们调入内存,但内存无空闲时,需要选择一页面换出到对换区,选择算法即页面置换算法;算法评价:页面置换频率低,调出页面将不会或很少访问;4.8.1 最佳置换算法和先进先出置换算法1. 最佳Optimal 置换算法由Belady 于1966年提出的一种理论上的算法;原理:其所选择的被淘汰页面,将是以后永不使用的, 或是在最长未来时间内不再被访问的页面;特点:通常可获得最低的缺页率,但由于进程运行不可预知而无法实现,用来评价其他算法;假定系统为某进程分配了三个物理块,并考虑有以下的页面号引用串:7,0,1,2,0,3,0,4,2,3,0,3,2,1,2,0,1,7,0,1进程运行时,先将7,0,1三页装入内存;当进程要访问页面2时,将会产生缺页中断,此时OS 根据最佳置换算法,将选择页面7予以淘汰;共发生6次页面置换;图 4-25 利用最佳页面置换算法时的置换图 2. 先进先出FIFO 页面置换算法---总是置换最先进入内存的页面;用FIFO 算法共发生12次页面置换;该算法与进程的实际运行规律不相符,有些页面经常被访问全局变量,常用函数;图 4-26 利用FIFO 置换算法时的置换图4.8.2 最近最久未使用Least Recently Used LRU 置换算法1. LRU置换算法 ---在无法预测各页面将来使用情况下,利用“最近过去”作为“最近将来”的近似选择最近最久未使用的页面予以淘汰;用LRU 算法共发生9次页面置换;引用率70770170122010320304243230321201201770101页框(物理块)203图 4-27 LRU 页面置换算法2. LRU 置换算法的硬件支持LRU 算法比较好,但为了快速知道哪一页是最近最久未使用的页面,需要硬件支持:寄存器或栈;1 寄存器为了记录某进程在内存中各页的使用情况,须为每个页面配置一个移位寄存器,可表示为:原理:进程访问某物理块时,先将寄存器的Rn-1位设成1;此时,定时信号将每隔一定时间将寄存器右移一位;若将n 位寄存器的数看做是一整数,那么,具有最小数值的寄存器所对应的页面,就是最近最久未使用的页面;例:某进程在内存中有8个页面,为每页面配置一8位寄存器时的LRU 访问情况,如图4-28图 4-28 某进程具有8个页面时的LRU 访问情况2 栈--利用栈来保存当前使用的各页面的页面号;原理:每当进程访问某页面时,便将该页面的页面号从栈中移出,将它压入栈顶;因此,栈顶始终是最新被访问页面的编号,而栈底则是最近最久未使用页面的页面号;假定现有一进程所访问的页面的页面号序列为:4,7,0,7,1,0,1,2,1,2,6随着进程的访问,栈中页面号的变化情况如图4-29所示;在访问页面6时发生了缺页,此时页面4是最近最久未被访问的页,应将它置换出去;LRU 算法较好,但要求较多硬件支持, 实际使用接近LRU算法-Clock 算法;图引用率70770170122010323104430230321013201770201页框2304204230230127127011474074704170401741074210741207421074621074-29 用栈保存当前使用页面时栈的变化情况。

计算机操作系统的内存和资源管理

计算机操作系统的内存和资源管理

计算机操作系统的内存和资源管理计算机操作系统是人类智慧的结晶,是计算机系统中最为重要的组成部分之一。

而计算机操作系统的内存和资源管理则是计算机系统中最为基础、且最为重要的技术之一。

那么,究竟什么是计算机操作系统的内存和资源管理呢?下面,我们将对其进行较为详细的介绍。

一、计算机操作系统内存管理内存是计算机系统中非常重要的部分,它能够存储大量的程序、数据以及指令等信息。

在计算机操作系统中,内存管理是至关重要的。

内存管理的主要功能是负责将系统中的内存空间进行分配、回收以及保护等操作。

在进行内存管理时,需要使用一些技术,如分页管理、分段管理和虚拟内存管理等。

1、分页管理技术分页管理技术是一种常用的内存管理技术。

它将物理内存按照固定大小的块进行划分,并将进程的虚拟空间也划分为大小相等的块,将进程中的数据和指令分别存放在不同的块中。

这种方式可以使得进程运行时不会发生冲突,从而保证了进程的安全性和稳定性。

2、分段管理技术分段管理技术是一种对内存进行划分的技术。

它将进程中的数据和指令按照功能、性质等进行划分,形成多个独立的逻辑段。

这些段具有不同的性质和对内存空间的需求,因此需要使用不同的管理策略。

使用这种技术可以有效地解决内存碎片问题,提高了内存的利用率。

3、虚拟内存管理技术虚拟内存管理技术是一种将物理内存和硬盘上的空间互相补充使用的技术。

在使用虚拟内存技术时,进程中只需要加载其部分数据到物理内存中,其余数据则存储在硬盘上。

当需要使用到存放在硬盘上的数据时,系统将其从硬盘中调入内存中,以供进程使用。

这种方式可以使得进程更加高效地使用内存,提高计算机系统的性能。

二、资源管理资源管理包括对CPU、磁盘、网络等主要硬件资源的管理。

在计算机操作系统中,资源管理是实现进程调度、磁盘、网络等系统资源的分配和控制的核心。

一般来讲,资源管理的主要目标是提高计算机系统的性能、提高系统吞吐量,并尽可能将每个进程的资源利用率最大化。

操作系统第四章复习

操作系统第四章复习

页框号为21。 因为起始驻留集为空, 而0页对应的ห้องสมุดไป่ตู้框为空闲链表中的第三个空闲页框,其对应的页框号为21。
页框号为32。 因为11 > 10故发生第三轮扫描,页号为1的页框在第二轮已经处于空闲页框链表中,此刻该页又被重新访问,因此应被重新放回到驻留集中,其页框号为32。
页框号为41。 因为第2页从来没有被访问过,不在驻留集中。因此从空闲链表中取出链表头的页框,页框号为41。
4. 在虚拟内存管理中,地址变换机构将逻辑地址转换为物理地址,形成该逻辑地址的阶段是( )。 ① 编辑 ② 编译 ③ 链接 ④ 装载 5. 采用段式存储管理的系统中,若地址用24位表示,其中8位表示段号,则允许每段的最大长度是_______ A)224 B)28 C) 216 D) 232 6. 作业在执行中发生了缺页中断,经操作系统处理后,应让其执行______指令。 A)被中断的前一条 B)被中断的后一条 C)被中断的 D) 启动时的第一条
7、某基于动态分区存储管理的计算机,其主存容量为55MB(初始为空),采用最佳适配(Best fit)算法,分配和释放的顺序为:分配15MB,分配30MB,释放15MB,分配6MB,此时主存中最大空闲分区的大小是( ) A:7MB B:9MB C:10MB D:15MB
当该进程执行到时刻260时,要访问逻辑地址为17CAH的数据,请问答下列问题: (1)该逻辑地址对应的页号是多少? (2)若采用先进先出置换算法,该逻辑地址对应的物理地址是多少?要求给出计算过程。 (3)若采用时钟置换算法,该逻辑地址对应的物理地址是多少?(设搜索下一页的指针沿顺时针方向移动,且当前指向2号页框)
页号
存储块号
0 1 2 3
5 10 4 7

操作系统第八版复习题答案

操作系统第八版复习题答案

操作系统第八版复习题答案操作系统第八版复习题答案操作系统是计算机系统中的核心组件,负责管理计算机的资源和提供各种服务。

对于学习操作系统的同学来说,复习题是一个很好的练习和巩固知识的方式。

本文将为大家提供操作系统第八版复习题的答案,希望能够对大家的学习有所帮助。

第一章:引论1. 操作系统是什么?答:操作系统是计算机系统中的核心软件,负责管理计算机的硬件资源和提供各种服务,是用户和计算机硬件之间的接口。

2. 操作系统的主要功能有哪些?答:操作系统的主要功能包括进程管理、内存管理、文件系统管理、设备管理和用户接口。

3. 什么是进程?答:进程是程序的执行实例,是计算机中正在运行的程序的抽象。

4. 进程和线程有什么区别?答:进程是程序的执行实例,拥有独立的地址空间和资源,而线程是进程中的一个执行单元,共享进程的地址空间和资源。

5. 什么是虚拟内存?答:虚拟内存是一种将磁盘空间作为扩展内存的技术,可以将进程的数据和指令存储在磁盘上,按需加载到内存中。

第二章:进程管理1. 进程的状态有哪些?答:进程的状态包括就绪态、运行态和阻塞态。

2. 进程调度的目标是什么?答:进程调度的目标是提高系统的吞吐量、响应时间和公平性。

3. 什么是死锁?答:死锁是指两个或多个进程因为争夺资源而相互等待的状态,导致系统无法继续执行。

4. 死锁的预防策略有哪些?答:死锁的预防策略包括资源分配策略、资源有序性策略和资源剥夺策略。

5. 什么是进程同步?答:进程同步是指多个进程之间按照一定的顺序执行,以避免竞态条件和数据不一致的问题。

第三章:内存管理1. 什么是虚拟内存?答:虚拟内存是一种将磁盘空间作为扩展内存的技术,可以将进程的数据和指令存储在磁盘上,按需加载到内存中。

2. 什么是页面置换算法?答:页面置换算法是指在内存不足时,选择一个页面将其换出到磁盘上,以便为新的页面腾出空间。

3. FIFO页面置换算法的缺点是什么?答:FIFO页面置换算法的缺点是无法考虑页面的访问频率和重要性,可能导致频繁访问的页面被置换出去。

操作系统-存储管理

操作系统-存储管理

操作系统-存储管理操作系统-存储管理一、引言存储管理是操作系统中重要的组成部分,它负责管理计算机系统中的存储器资源。

存储管理的任务包括内存分配、内存保护、内存回收等,通过有效的存储管理可以充分利用系统的存储资源,提高系统的运行效率和性能。

二、内存层次结构1、主存储器主存储器是计算机系统中最主要的存储器,它用于存放正在运行的程序和数据,是CPU直接访问的存储器。

主存储器一般被划分为若干个固定大小的块,每个块被称为一页,每一页可以存放一个进程的一部分或全部。

2、辅助存储器辅助存储器是主存储器的扩展,主要用于存储大容量的数据和程序。

辅助存储器包括硬盘、磁带等设备,其访问速度比主存储器慢,但容量较大。

三、内存管理1、内存分配方式a:静态分配静态分配是指在程序运行之前,就确定了程序在内存中的位置。

静态分配的优点是简单高效,但是会浪费存储资源。

b:动态分配动态分配是指程序在运行时,根据需要动态分配内存。

动态分配的优点是灵活高效,但是需要额外的内存管理开销。

2、内存管理算法a:首次适应算法首次适应算法是按照内存块的起始地质逐一查找,找到第一个大小大于等于要求的空闲的内存块进行分配。

b:最佳适应算法最佳适应算法是在所有满足要求的内存块中选择大小最小的内存块进行分配。

c:最差适应算法最差适应算法是在所有满足要求的内存块中选择大小最大的内存块进行分配。

3、内存保护内存保护是指通过访问权限控制,确保每个进程只能访问自己分配的内存空间,防止进程之间的干扰。

4、内存回收内存回收是指当进程不再使用某些内存空间时,将其释放给系统以便后续的内存分配。

内存回收可以通过标记清除算法、引用计数算法等方式实现。

四、虚拟内存管理1、虚拟内存机制虚拟内存是一种扩展的内存管理技术,它通过将部分程序或数据装入主存储器,并实现从辅助存储器到主存储器的动态迁移,提高了计算机系统的运行性能。

2、页面置换算法页面置换算法是指当主存储器已满时,需要置换出某些页面到辅助存储器中,以便为新的页面腾出空间。

操作系统(二)复习

操作系统(二)复习

第四章 存储器管理
存储管理的主要功能 1. 地址转换(地址映射) 2. 存储器的分配和回收 3. 存储保护 4. 存储扩充
有那些分配的方式,有那些分配的算法,各需要那 些数据结构,如何实现地址转换和存储扩充; 各种方式的优缺点(内存利用率、内零头和碎片)。
地址转换(地址映射、地址重定位)
• 概念: 逻辑地址 地址空间 物理地址 存储空间(物理空间) 方式: 静态地址转换和动态地址转换的区别,实 现过程,优缺点,每种存储分配方式对应 的地址转换是如何实现的。
页式管理和段式管理的比较
页式
大小 信息 目的 逻辑 地址 固定、硬件决定 信息的物理单位 提高内存的利用率 一维的
段式
不固定、程序决定 独立的信息逻辑单位, 更便于共享 方便程序设计 二维的
段页式管理
• 段式和页式的结合,取长补短。 • 逻辑地址:二维的 • 数据结构:每个进程一张段表(页表地址 和页表长度),每个段一张页表,位示图。 • 地址转换:硬件实现的动态地址转换机构, 要访问3次内存。
虚拟存储器
• 局部性(局限性) 时间局部性和空间局部性。 • 硬件支持:动态地址转换机构 + 中断(缺页中断、 缺段中断) • 特征:离散性、多次性、对换性、虚拟性 • 效果:大于内存配置的容量、接近内存的速度、 接近外存的单位价格。 • 容量(地址空间): MIN(地址结构可表示的大小,内存+外存)
第四章 设备管理
设备管理的主要功能 • 设备分配、调度 • 缓冲管理 • 设备处理 • 实现设备的无关性和虚拟设备
提高CPU和设备并行工作的程度,设备和设 备并行工作的程度。
设备类型
独占型设备、共享型设备、虚拟型设备
字符型设备。块设备
大中小型计算机的设备连接方式
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

操作系统内存管理操作系统内存管理1. 内存管理方法内存管理主要包括虚地址、地址变换、内存分配和回收、内存扩充、内存共享和保护等功能。

2. 连续分配存储管理方式连续分配是指为一个用户程序分配连续的内存空间。

连续分配有单一连续存储管理和分区式储管理两种方式。

2.1 单一连续存储管理在这种管理方式中,内存被分为两个区域:系统区和用户区。

应用程序装入到用户区,可使用用户区全部空间。

其特点是,最简单,适用于单用户、单任务的操作系统。

CP/M和 DOS2.0以下就是采用此种方式。

这种方式的最大优点就是易于管理。

但也存在着一些问题和不足之处,例如对要求内存空间少的程序,造成内存浪费;程序全部装入,使得很少使用的程序部分也占用—定数量的内存。

2.2 分区式存储管理为了支持多道程序系统和分时系统,支持多个程序并发执行,引入了分区式存储管理。

分区式存储管理是把内存分为一些大小相等或不等的分区,操作系统占用其中一个分区,其余的分区由应用程序使用,每个应用程序占用一个或几个分区。

分区式存储管理虽然可以支持并发,但难以进行内存分区的共享。

分区式存储管理引人了两个新的问题:内碎片和外碎片。

内碎片是占用分区内未被利用的空间,外碎片是占用分区之间难以利用的空闲分区(通常是小空闲分区)。

为实现分区式存储管理,操作系统应维护的数据结构为分区表或分区链表。

表中各表项一般包括每个分区的起始地址、大小及状态(是否已分配)。

分区式存储管理常采用的一项技术就是内存紧缩(compaction)。

2.2.1 固定分区(nxedpartitioning)。

固定式分区的特点是把内存划分为若干个固定大小的连续分区。

分区大小可以相等:这种作法只适合于多个相同程序的并发执行(处理多个类型相同的对象)。

分区大小也可以不等:有多个小分区、适量的中等分区以及少量的大分区。

根据程序的大小,分配当前空闲的、适当大小的分区。

优点:易于实现,开销小。

缺点主要有两个:内碎片造成浪费;分区总数固定,限制了并发执行的程序数目。

2.2.2动态分区(dynamic partitioning)。

动态分区的特点是动态创建分区:在装入程序时按其初始要求分配,或在其执行过程中通过系统调用进行分配或改变分区大小。

与固定分区相比较其优点是:没有内碎片。

但它却引入了另一种碎片——外碎片。

动态分区的分区分配就是寻找某个空闲分区,其大小需大于或等于程序的要求。

若是大于要求,则将该分区分割成两个分区,其中一个分区为要求的大小并标记为“占用”,而另一个分区为余下部分并标记为“空闲”。

分区分配的先后次序通常是从内存低端到高端。

动态分区的分区释放过程中有一个要注意的问题是,将相邻的空闲分区合并成一个大的空闲分区。

下面列出了几种常用的分区分配算法:最先适配法(nrst-fit):按分区在内存的先后次序从头查找,找到符合要求的第一个分区进行分配。

该算法的分配和释放的时间性能较好,较大的空闲分区可以被保留在内存高端。

但随着低端分区不断划分会产生较多小分区,每次分配时查找时间开销便会增大。

下次适配法(循环首次适应算法 next fit):按分区在内存的先后次序,从上次分配的分区起查找(到最后{区时再从头开始},找到符合要求的第一个分区进行分配。

该算法的分配和释放的时间性能较好,使空闲分区分布得更均匀,但较大空闲分区不易保留。

最佳适配法(best-fit):按分区在内存的先后次序从头查找,找到其大小与要求相差最小的空闲分区进行分配。

从个别来看,外碎片较小;但从整体来看,会形成较多外碎片优点是较大的空闲分区可以被保留。

最坏适配法(worst- fit):按分区在内存的先后次序从头查找,找到最大的空闲分区进行分配。

基本不留下小空闲分区,不易形成外碎片。

但由于较大的空闲分区不被保留,当对内存需求较大的进程需要运行时,其要求不易被满足。

2.3 伙伴系统固定分区和动态分区方式都有不足之处。

固定分区方式限制了活动进程的数目,当进程大小与空闲分区大小不匹配时,内存空间利用率很低。

动态分区方式算法复杂,回收空闲分区时需要进行分区合并等,系统开销较大。

伙伴系统方式是对以上两种内存方式的一种折衷方案。

伙伴系统规定,无论已分配分区或空闲分区,其大小均为 2 的 k 次幂,k 为整数, l≤k≤m,其中:2^1 表示分配的最小分区的大小,2^m 表示分配的最大分区的大小,通常 2^m是整个可分配内存的大小。

假设系统的可利用空间容量为2^m个字,则系统开始运行时,整个内存区是一个大小为2^m的空闲分区。

在系统运行过中,由于不断的划分,可能会形成若干个不连续的空闲分区,将这些空闲分区根据分区的大小进行分类,对于每一类具有相同大小的所有空闲分区,单独设立一个空闲分区双向链表。

这样,不同大小的空闲分区形成了k(0≤k≤m)个空闲分区链表。

分配步骤:当需要为进程分配一个长度为n 的存储空间时:首先计算一个i 值,使 2^(i-1) &lt;n ≤ 2^i,然后在空闲分区大小为2^i的空闲分区链表中查找。

若找到,即把该空闲分区分配给进程。

否则,表明长度为2^i的空闲分区已经耗尽,则在分区大小为2^(i+1)的空闲分区链表中寻找。

若存在 2^(i+1)的一个空闲分区,则把该空闲分区分为相等的两个分区,这两个分区称为一对伙伴,其中的一个分区用于配,而把另一个加入分区大小为2^i的空闲分区链表中。

若大小为2^(i+1)的空闲分区也不存在,则需要查找大小为2^(i+2)的空闲分区,若找到则对其进行两次分割:第一次,将其分割为大小为 2^(i+1)的两个分区,一个用于分配,一个加入到大小为 2^(i+1)的空闲分区链表中;第二次,将第一次用于分配的空闲区分割为 2^i的两个分区,一个用于分配,一个加入到大小为 2^i的空闲分区链表中。

若仍然找不到,则继续查找大小为 2^(i+3)的空闲分区,以此类推。

由此可见,在最坏的情况下,可能需要对 2^k的空闲分区进行 k 次分割才能得到所需分区。

与一次分配可能要进行多次分割一样,一次回收也可能要进行多次合并,如回收大小为2^i的空闲分区时,若事先已存在2^i的空闲分区时,则应将其与伙伴分区合并为大小为2^i+1的空闲分区,若事先已存在2^i+1的空闲分区时,又应继续与其伙伴分区合并为大小为2^i+2的空闲分区,依此类推。

在伙伴系统中,其分配和回收的时间性能取决于查找空闲分区的位置和分割、合并空闲分区所花费的时间。

与前面所述的多种方法相比较,由于该算法在回收空闲分区时,需要对空闲分区进行合并,所以其时间性能比前面所述的分类搜索算法差,但比顺序搜索算法好,而其空间性能则远优于前面所述的分类搜索法,比顺序搜索法略差。

需要指出的是,在当前的操作系统中,普遍采用的是下面将要讲述的基于分页和分段机制的虚拟内存机制,该机制较伙伴算法更为合理和高效,但在多处理机系统中,伙伴系统仍不失为一种有效的内存分配和释放的方法,得到了大量的应用。

2.4 内存紧缩内存紧缩:将各个占用分区向内存一端移动,然后将各个空闲分区合并成为一个空闲分区。

这种技术在提供了某种程度上的灵活性的同时,也存在着一些弊端,例如:对占用分区进行内存数据搬移占用CPU时间;如果对占用分区中的程序进行“浮动”,则其重定位需要硬件支持。

紧缩时机:每个分区释放后,或内存分配找不到满足条件的空闲分区时。

图8.12堆结构的存储管理的分配算法:在动态存储过程中,不管哪个时刻,可利用空间都是-一个地址连续的存储区,在编译程序中称之为"堆",每次分配都是从这个可利用空间中划出一块。

其实现办法是:设立一个指針,称之为堆指针,始终指向堆的最低(或锻联)地址。

当用户申请N个单位的存储块时,堆指针向高地址(或低地址)称动N个存储单位,而移动之前的堆指针的值就是分配给用户的占用块的初始地址。

例如,某个串处理系统中有A、B、C、D这4个串,其串值长度分别為12,6,10和8. 假设堆指针free的初值为零,则分配给这4个串值的存储空间的初始地址分别为0.12.18和28,如图8.12(a)和(b)所示,分配后的堆指针的值为36。

因此,这种堆结构的存储管理的分配算法非常简单,释放内存空间执行内存紧缩:回收用户释放的空闲块就比较麻烦.由于系统的可利用空间始终是一个绝址连续的存储块,因此回收时必须将所释放的空间块合并到整个堆上去才能重新使用,这就是"存储策缩"的任务.通常,有两种做法:一种是一旦有用户释放存储块即进行回收紧缩,例始,图8.12 (a)的堆,在c串释放存储块时即回收紧缩,例如图8.12 (c)的堆,同时修改串的存储映像成图8.12(d)的状态;另一种是在程序执行过程中不回收用户随时释放的存储块,直到可利用空同不够分配或堆指针指向最高地址时才进行存储紧缩。

此时紧缩的目的是将堆中所有的空间块连成一块,即将所有的占用块部集中到可利用空间的低地地区,而剩余的高地址区成为一整个地继连续的空闲块,如图8.13所示,其中(a)为紧缩前的状态,(b)为紧缩后的状态·图8.13 a 紧缩前 b紧缩后和无用单元收集类似,为实现存储紫编,首先要对占用块进行“标志”,标志算法和无用单元收集类同(存储块的结构可能不同),其次需进行下列4步雄作:(1)计算占用块的新地址。

从最低地址开始巡査整个存储空间,对每一个占用块找到它在紧缩后的新地址。

为此,需设立两个指针随巡查向前移动,这两个指针分别指示占用块在紧缩之前和之后的原地址和新地址。

因此,在每个占用块的第-·个存储单位中,除了设立长度域(存储该占用换的大小)和标志域(存储区别该存储块是占用块或空闲块的标志)之外,还需设立一个新地址城,以存储占用块在紧缩后应有的新地址,即建立一张新,旧地址的对照表m(2)修改用户触初始变量表,以便在存储紧缩后用户程序能继续正常运行*。

(3)检查每个占用块中存储的数据,若有指向其他存储换的指针,则需作相应修改.(4)将所有占用块迁移到新地址走,这实质上是作传送数据的工作。

至此,完成了存储紧缩的操作,最后,将堆指针赋以新值(即紧缩后的空闲存储区的最低地址)。

可见,存储紧缩法比无用单元收集法更为复杂,前者不仅要传送数据(进行占用块迁移),而且还有需要修改所有占用块中的指针值。

因此,存储紧缩也是个系统操作,且非不得已就不用。

3. 覆盖和交换技术3.1 覆盖技术引入覆盖 (overlay)技术的目标是在较小的可用内存中运行较大的程序。

这种技术常用于多道程序系统之中,与分区式存储管理配合使用。

覆盖技术的原理:一个程序的几个代码段或数据段,按照时间先后来占用公共的内存空间。

将程序必要部分(常用功能)的代码和数据常驻内存;可选部分(不常用功能)平时存放在外存(覆盖文件)中,在需要时才装入内存。

相关文档
最新文档