




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、操作系统内存管理1. 内存管理方法内存管理主要包括虚地址、地址变换、内存分配和 回收、内存扩充、内存共享和保护等功能。 2. 连续分配存 储管理方式连续分配是指为一个用户程序分配连续的内存空间。 连续分配有单一连续存储管理和分区式储管理两种方式。2.1 单一连续存储管理在这种管理方式中,内存被分为两个区域:系统区和 用户区。应用程序装入到用户区,可使用用户区全部空间。 其特点是,最简单,适用于单用户、单任务的操作系统。 CP M 和 DOS20 以下就是采用此种方式。 这种方式的最大优点就是易于 管理。但也存在着一些问题和不足之处,例如对要求内存空 间少的程序,造成内存浪费;程序全部装入,使得
2、很少使用的程序部分也占用定数量的内存 2.2 分区式存储管理为了支持多道程序系统和分时系统,支持多个程序 并发执行,引入了分区式存储管理。分区式存储管理是把内 存分为一些大小相等或不等的分区,操作系统占用其中一个 分区,其余的分区由应用程序使用,每个应用程序占用一个 或几个分区。分区式存储管理虽然可以支持并发,但难以进 行内存分区的共享。分区式存储管理引人了两个新的问题:内碎片和外 碎片。内碎片是占用分区内未被利用的空间,外碎片是占用 分区之间难以利用的空闲分区 (通常是小空闲分区 )。为实现分区式存储管理,操作系统应维护的数据结 构为分区表或分区链表。表中各表项一般包括每个分区的起 始地址、
3、大小及状态 (是否已分配 ) 。分区式存储管理常采用的一项技术就是内存紧缩(compaction) 。2.2.1 固定分区 (nxedpartitioning) 。固定式分区的特点是把内存划分为若干个固定大 小的连续分区。分区大小可以相等:这种作法只适合于多个 相同程序的并发执行 (处理多个类型相同的对象 )。分区大小 也可以不等:有多个小分区、适量的中等分区以及少量的大 分区。 根据程序的大小, 分配当前空闲的、 适当大小的分区。优点:易于实现,开销小。缺点主要有两个:内碎片造成浪费;分区总数固定, 限制了并发执行的程序数目。2.2.2 动态分区 (dynamic partitioning)
4、 。动态分区的特点是动态创建分区:在装入程序时按 其初始要求分配,或在其执行过程中通过系统调用进行分配 或改变分区大小。 与固定分区相比较其优点是: 没有内碎片 但它却引入了另一种碎片外碎片。动态分区的分区分配 就是寻找某个空闲分区,其大小需大于或等于程序的要求。若是大于要求,则将该分区分割成两个分区,其中一个分区 为要求的大小并标记为“占用” ,而另一个分区为余下部分 并标记为“空闲” 。分区分配的先后次序通常是从内存低端 到高端。动态分区的分区释放过程中有一个要注意的问题 是,将相邻的空闲分区合并成一个大的空闲分区。下面列出了几种常用的分区分配算法:最先适配法 (nrst-fit) :按分
5、区在内存的先后次序从头 查找,找到符合要求的第一个分区进行分配。该算法的分配 和释放的时间性能较好,较大的空闲分区可以被保留在内存 高端。但随着低端分区不断划分会产生较多小分区,每次分 配时查找时间开销便会增大。下次适配法 (循环首次适应算法 next fit) :按分区在 内存的先后次序,从上次分配的分区起查找(到最后 区时再从头开始 ,找到符合要求的第一个分区进行分配。该算法 的分配和释放的时间性能较好,使空闲分区分布得更均匀, 但较大空闲分区不易保留。最佳适配法 (best-fit) :按分区在内存的先后次序从头 查找,找到其大小与要求相差最小的空闲分区进行分配。从个别来看,外碎片较小;
6、但从整体来看,会形成较多外碎片 优点是较大的空闲分区可以被保留。最坏适配法 (worst- fit) :按分区在内存的先后次序从 头查找,找到最大的空闲分区进行分配。基本不留下小空闲 分区,不易形成外碎片。但由于较大的空闲分区不被保留, 当对内存需求较大的进程需要运行时,其要求不易被满足。2.3 伙伴系统固定分区和动态分区方式都有不足之处。固定分区 方式限制了活动进程的数目,当进程大小与空闲分区大小不 匹配时,内存空间利用率很低。动态分区方式算法复杂,回 收空闲分区时需要进行分区合并等,系统开销较大。伙伴系 统方式是对以上两种内存方式的一种折衷方案。伙伴系统规定,无论已分配分区或空闲分区,其大
7、小均为2的k次幕,k为整数,I k m,其中:2A1表示分配的最小分区的大小,2Am表示分配的最大分区的大小,通常2Am是整个可分配内存的大小假设系统的可利用空间容量为2“m个字,则系统开始运行时, 整个内存区是一个大小为 2Am 的空闲分区。 在系统运行过中, 由于不断的划分,可能会形成若干个不 连续的空闲分区,将这些空闲分区根据分区的大小进行分 类,对于每一类具有相同大小的所有空闲分区,单独设立一 个空闲分区双向链表。 这样,不同大小的空闲分区形成了 k(0 k m)个空闲分区链表。分配步骤:当需要为进程分配一个长度为 n 的存储空间时 :首先计算一个i值,使2A(i - 1) <n
8、 2Ai ,然后在空闲分区大小为 2Ai 的空闲分区链表中查找。若找到,即把该空闲分区分配给进程。否则, 表明长度为 2Ai 的空闲分区已经耗尽, 则在分区大小为2A(i + 1)的空闲分区链表中寻找若存在2A(i + 1)的一个空闲分区,则把该空闲分区分 为相等的两个分区,这两个分区称为一对伙伴,其中的一个 分区用于配, 而把另一个加入分区大小为 2Ai 的空闲分区 链表中。若大小为 2A(i 1)的空闲分区也不存在, 则需要查找 大小为 2A(i 2)的空闲分区,若找到则对其进行两次分割:第一次,将其分割为大小为 2A(i 1)的两个 分区,一个用于分配,一个加入到大小为2A(i + 1)
9、的空闲分区链表中;第二次,将第一次用于分配的空闲区分割为 2Ai 的两个分区,一个用于分配,一个加入到大小为 2Ai 的 空闲分区链表中。若仍然找不到,则继续查找大小为2A(i + 3)的空闲分区,以此类推。由此可见, 在最坏的情况下, 可能需要对 2Ak 的空闲分区进行 k 次分割才能得到所需分区。与一次分配可能要进行多次分割一样,一次回收也可能要进行多次合并,如回收大小为2Ai的空闲分区时,若事先已存在2Ai的空闲分区时,则应将其与伙伴分区合并为大 小为 2Ai1 的空闲分区,若事先已存在 2Ai1 的空闲分区 时,又应继续与其伙伴分区合并为大小为2Ai + 2的空闲分区,依此类推。在伙伴
10、系统中,其分配和回收的时间性能取决于查 找空闲分区的位置和分割、合并空闲分区所花费的时间。与 前面所述的多种方法相比较,由于该算法在回收空闲分区 时,需要对空闲分区进行合并,所以其时间性能比前面所述 的分类搜索算法差,但比顺序搜索算法好,而其空间性能则 远优于前面所述的分类搜索法,比顺序搜索法略差。 需要 指出的是,在当前的操作系统中,普遍采用的是下面将要讲 述的基于分页和分段机制的虚拟内存机制,该机制较伙伴算 法更为合理和高效,但在多处理机系统中,伙伴系统仍不失 为一种有效的内存分配和释放的方法,得到了大量的应用。2.4 内存紧缩内存紧缩:将各个占用分区向内存一端移动,然 后将各个空闲分区合
11、并成为一个空闲分区。这种技术在提供了某种程度上的灵活性的同时,也 存在着一些弊端,例如:对占用分区进行内存数据搬移占用 CPU 时间;如果对占用分区中的程序进行“浮动” ,则其重 定位需要硬件支持。紧缩时机:每个分区释放后,或内存分配找不到 满足条件的空闲分区时。图 8.12堆结构的存储管理的分配算法: 在动态存储过程中,不管哪个时刻,可利用空间都是-一个地址连续的存储区,在编译程序中称之为堆 ,每次分配都是从这个可利用空间中划出一块。其实现办法是:设立 一个指針,称之为堆指针,始终指向堆的最低(或锻联)地 址。当用户申请 N 个单位的存储块时,堆指针向高地址(或 低地址) 称动 N 个存储单
12、位, 而移动之前的堆指针的值就是 分配给用户的占用块的初始地址。例如,某个串处理系统中 有 A 、B 、C、D 这 4 个串,其串值长度分别為 12,6,10 和 8. 假 设堆指针 free 的初值为零,则分配给这 4 个串值的存储空间 的初始地址分别为 0.12.18 和28,如图8.12(a)和(b)所示,分配后的堆指针的值为36。因此,这种堆结构的存储管理的分配算法非常简单,释放内存空间执行内存紧缩:回收用户释放的空闲块就比较麻烦.由于系统的可利用空间始终是一个绝址连续的存储块,因此回收时必须将所释 放的空间块合并到整个堆上去才 能重新使用,这就是 存储 策缩的任务 .通常,有两种做法
13、:一种是一旦有用户释放存储块即进行回收紧缩,例始,图8.12 (a)的堆,在c串释放存储块时即回收紧缩,例如 图8.12 (c)的堆,同时修改串的存储映像成图8.12(d)的状态;另一种是在程序执行过程中不回收用户随时释放的存 储块,直到可利用空同不够分配或堆指针指向最高地址时才 进行存储紧缩。此时紧缩的目的是将堆中所有的空间块连成 一块,即将所有的占用块部集中到 可利用空间的低地地区, 而剩余的高地址区成为一整个地继连续的空闲块,如图 8.13 所示,其中(a)为紧缩前的状态,(b)为紧缩后的状态图 8.13 a 紧缩前 b 紧缩后和无用单元收集类似,为实现存储紫编 ,首先要对占 用块进行“
14、标志” ,标志算法和无用单元收集类同 (存储块的 结构可能不同) ,其次需进行下列 4 步雄作:( 1)计算占用块的新地址。从最低地址开始巡査整个 存储空间,对每一个占用块找到它在紧缩后的新地址。 为 此,需设立两个指针随巡查向前移动 ,这两个指针分别指示占 用 块在紧缩之前和之后的原地址和新地址。因此,在每个占用块的第-个存储单位中,除了 设立长度域(存储该占用换 的大小)和标志域 (存储区别该存储块是占用块或空闲块的标 志)之外,还需设立一个新地址城,以存储占用块在紧缩后 应有的新地址,即建立一张新, 旧地址的对照表 m(2) 修改用户触初始变量表,以便在存储紧缩后用户 程序能继续正常运行
15、 * 。(3) 检查每个占用块中存储的数据, 若有指向其他存 储换的指针,则需作相应修改 .(4) 将所有占用块迁移到新地址走,这实质上是作传 送数据的工作。至此,完成了存储紧缩的操作,最后 ,将堆指针赋以 新值(即紧缩后的空闲存储区的最低地址) 。可见 ,存储紧缩法比无用单元收集法更为复杂,前者 不仅要传送数据(进行占用块迁移) ,而且还有需要修改所 有占用块中的指针值。因此,存储紧缩也是个系统操作,且 非不得已就不用。3. 覆盖和交换技术3.1 覆盖技术引入覆盖 (overlay) 技术的目标是在较小的可用内 存中运行较大的程序。这种技术常用于多道程序系统之中, 与分区式存储管理配合使用。
16、覆盖技术的原理:一个程序的几个代码段或数据段, 按照时间先后来占用公共的内存空间。 将程序必要部分 (常用 功能 )的代码和数据常驻内存;可选部分 (不常用功能 )平时存 放在外存 (覆盖文件 )中,在需要时才装入内存。不存在调用 关系的模块不必同时装入到内存,从而可以相互覆盖。在任何时候只在内存中保留所需的指令和数据;当 需要其它指令时,它们会装入到刚刚不再需要的指令所占用 的内存空间;如在同一时刻, CPU 只能执行 B,C 中某一条。 B, C 之间就可以做覆盖。覆盖技术的缺点是编程时必须划分程序模块和确定 程序模块之间的覆盖关系,增加编程复杂度;从外存装入覆 盖文件,以时间延长换取空间
17、节省。覆盖的实现方式有两种:以函数库方式实现或操作系 统支持。3.2 交换技术交换 (swapping) 技术在多个程序并发执行时,可以将 暂时不能执行的程序(进程)送到外存中,从而获得空闲内 存空间来装入新程序(进程) ,或读人保存在外存中而处于 就绪状态的程序。交换单位为整个进程的地址空间。交换技 术常用于多道程序系统或小型分时系统中,因为这些系统大 多采用分区存储管理方式。与分区式存储管理配合使用又称 作“对换”或“滚进滚出” (roll-in roll-out) 。原理:暂停执行内存中的进程,将整个进程的地址空 间保存到外存的交换区中(换出swap out),而将外存中由阻塞变为就绪的
18、进程的地址空间读入到内存中,并将该进程送 到就绪队列(换入 swap in)。交换技术优点之一是增加并发运行的程序数目,并给 用户提供适当的响应时间;与覆盖技术相比交换技术另一个 显著的优点是不影响程序结构。交换技术本身也存在着不 足,例如:对换人和换出的控制增加处理器开销;程序整个 地址空间都进行对换,没有考虑执行过程中地址访问的统计 特性。3.3 覆盖与交换比较1)与覆盖技术相比,交换不要求程序员给出程序段 之间的覆盖结构。2)交换主要是在进程与作业之间进行,而覆盖则主 要在同一作业或进程内进行。 另外覆盖只能覆盖那些与覆 盖程序段无关的程序段。 4. 页式和段式存储管理在前面的几种存储管
19、理方法中,为进程分配的空 间是连续的,使用的地址都是物理地址。如果允许将一个进 程分散到许多不连续的空间,就可以避免内存紧缩,减少碎 片。基于这一思想,通过引入进程的逻辑地址,把进程地址空间与实际存储空间分离,增加存储管理的灵活性。地址空间和存储空间两个基本概念的定义如下: 地址空间:将源程序经过编译后得到的目标程序,存在于它 所限定的地址范围内,这个范围称为地址空间。地址空间是 逻辑地址的集合。存储空间:指主存中一系列存储信息的物理单元的集合,这 些单元的编号称为物理地址存储空间是物理地址的集合。根据分配时所采用的基本单位不同,可将离散分配的管理方 式分为以下三种:页式存储管理、段式存储管理
20、和段页式存储管理。其中段页 式存储管理是前两种结合的产物。5. 页式存储管理4.1 基本原理将程序的逻辑地址空间划分为固定大小的页(page),而物理内存划分为同样大小的页框(pageframe)。程序加载时,可将任意一页放人内存中任意一个页 框,这些页框不必连续,从而实现了离散分配。该方法需要 CPU 的硬件支持,来实现逻辑地址和物理地址之间的映射。 在页式存储管理方式中地址结构由两部构成,前一部分是页 号,后一部分为页内地址 w (位移量),如图4所示:页式管理方式的优点是:1)没有外碎片,每个内碎片不超过页大比前面所讨 论的几种管理方式的最大进步是,2)一个程序不必连续存放。3)便于改变
21、程序占用空间的大小 (主要指随着程序运行,动态生成的数据增多,所要求的地址空间相应增长)。缺点是:要求程序全部装入内存,没有足够的内存,程序就不能执行4.2 页式管理的数据结构在页式系统中进程建立时,操作系统为进程中所 有的页分配页框。当进程撤销时收回所有分配给它的页框。 在程序的运行期间,如果允许进程动态地申请空间,操作系 统还要为进程申请的空间分配物理页框。操作系统为了完成 这些功能,必须记录系统内存中实际的页框使用情况。操作 系统还要在进程切换时,正确地切换两个不同的进程地址空 间到物理内存空间的映射。这就要求操作系统要记录每个进 程页表的相关信息。 为了完成上述的功能, 个页式系统中,
22、 一般要采用如下的数据结构。进程页表:完成逻辑页号 (本进程的地址空间 )到物 理页面号 ( 实际内存空间,也叫块号 )的映射。每个进程有一个页表,描述该进程占用的物理页面 及逻辑排列顺序,如图:图 4-1 页表物理页面表:整个系统有一个物理页面表,描述物 理内存空间的分配使用状况,其数据结构可采用位示图和空 闲页链表。对于位示图法,即如果该页面已被分配,则对应比 特位置 1,否置 0.图 4-2 页面表请求表:整个系统有一个请求表,描述系统内各个 进程页表的位置和大小,用于地址转换也可以结合到各进程 的 PCB( 进程控制块 )里。如图:图 4-3 请求表4.3 页式管理地址变换在页式系统中
23、,指令所给出的地址分为两部分:逻辑页号和页内地址原理: CPU 中的内存管理单元 (MMU) 按逻辑页号通 过查进程页表得到物理页框号,将物理页框号与页内地址相 加形成物理地址 (见图 4-4) 。逻辑页号,页内偏移地址 > 查进程页表,得物 理页号 > 物理地址:图 4-4 页式管 理的地址变换上述过程通常由处理器的硬件直接完成,不需要软 件参与。通常,操作系统只需在进程切换时,把进程页表的 首地址装入处理器特定的寄存器中即可。一般来说,页表存 储在主存之中。这样处理器每访问一个在内存中的操作数, 就要访问两次内存:第一次用来查找页表将操作数的 逻辑地址变换为 物理地址;第二次完
24、成真正的读写操作这样做时间上耗费严重。为缩短查找时间,可以将页 表从内存装入 CPU 内部的关联存储器 (例如,快表 ) 中,实 现按内容查找。 此时的地址变换过程是: 在 CPU 给出有效地 址后,由地址变换机构自动将页号送人快表,并将此页号与 快表中的所有页号进行比较,而且这 种比较是同时进行的。 若其中有与此相匹配的页号,表示要访问的页的页表项在快 表中。于是可直接读出该页所对应的物理页号,这样就无需 访问内存中的页表。由于关联存储器的访问速度比内存的访 问速度快得多。5. 段式存储管理5.1 基本原理在段式存储管理中,将程序的地址空间划分为若干 个段(segment),这样每个进程有一
25、个二维的地址空间。在前 面所介绍的动态分区分配方式中,系统为整个进程分配一个 连续的内存空间。而在段式存储管理系统中,则为每个段分 配一个连续的分区,而进程中的各个段可以不连续地存放在 内存的不同分区中。程序加载时,操作系统为所有段分配其 所需内存,这些段不必连续,物理内存的管理采用动态分区 的管理方法。在为某个段分配物理内存时,可以采用首先适配法、 下次适配法、最佳适配法等方法。在回收某个段所占用的空间时,要注意将收回的空间 与其相邻的空间合并。段式存储管理也需要硬件支持,实现逻辑地址到物理 地址的映射。程序通过分段划分为多个模块,如代码段、数据段、 共享段:-可以分别编写和编译-可以针对不同类型的段采取不同的保护-可以按段为单位来进行共享,包括通过动态链接进行代码共享这样做的优点是:可以分别编写和编译源程序的一个 文件,并且可以针对不同类型的段采取不同的保护,也可以 按段为单位来进行共享。总的来说,段式存储管理的优点是:没有内碎片, 外碎片可以通过内存紧缩来消除;便于实现内存共享。缺点 与页式存储管理的缺点相同,进程必须全部装入内存。5.2 段式管理的数据结构为了实现段式管理,操作系统需要如下的数据结构来实现进程的地址空间到物理内存空间的映射
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 工业互联网平台射频识别(RFID)技术创新在智能交通管理中的应用研究报告
- 2025年餐饮行业顾客满意度调查与分析报告
- 小学生眼保健操课件版
- 企业盘点盘存管理办法
- 仓库常用材料管理办法
- 保险销售提成管理办法
- 企业配送运输管理办法
- 价格设置复核管理办法
- 产前超声检查管理办法
- 企业合同档案管理办法
- 2024年10月中国邮政储蓄银行大连分行社会招聘笔试历年参考题库附带答案详解
- 杭州婚姻介绍管理办法
- 老师心理健康课件
- 悬灸技术课件
- 2025年广西中考英语真题(原卷版)
- 2025年兵团职工面试试题及答案
- 2025年西式面点师(技师)考试必刷题库(含答案)
- 生产现场改善方案(3篇)
- 麻醉术中肺水肿临床处理与预防
- 2025年合肥瑶海学前教育有限责任公司招聘题库带答案分析
- 光学玻璃项目可行性研究报告模板范文(立项备案项目申请)
评论
0/150
提交评论