《【教学课件】第五章存储管理.ppt》由会员分享,可在线阅读,更多相关《【教学课件】第五章存储管理.ppt(65页珍藏版)》请在三一办公上搜索。
1、第五章 存储管理,5.1 存储管理的功能 5.2 分区存储管理5.3 覆盖与交换技术5.4 页式管理5.5 段式与段页式管理5.6 局部性原理和抖动问题,5.1 存储管理的功能,存储器的扩充地址变换和重定位存储空间分配存储保护,5.1.1 虚拟存储器:,利用OS的手段来实现存储器扩充的一种技术。不考虑物理存储器的大小和信息存放的实际位置,只规定每个进程中互相关联的信息的相对位置。每个进程都有自己的虚拟存储器,且虚拟的容量受计算机的地址结构和寻址方式的影响。,虚地址空间和实地址空间,程序访问的地址是虚地址,它可以访问的虚地址范围叫做程序的虚地址空间。,在指定的计算机系统中,可使用的实地址范围叫做
2、计算机的实地址空间。,实现虚拟存储技术注意的问题,需要有相当容量的辅存以便足以存放多个用户作业的地址空间要有一定容量的主存地址变换机构存储保护,源程序,编译,链接,虚拟空间,地址变换,物理存储器,地址变换和物理存储器,5.1.2 地址变换和重定位,1.地址映射,为保证程序正常运行,必须将逻辑地址正确地转换为物理地址,这种地址转换机构称为地址映射.,地址映射方式,就是建立虚地址到实地址之间的对应关系,也就是实现虚地址到实地址的一个对应.,jump 1400load 2200,1000,1400,2200,jump 1400load 2200,绝对地址,jump 1400load 2200,0,4
3、00,1200,jump 400load 1200,相对地址,绝对装入,引入相对地址的好处:,可以让OS进行分配空间减少了内存对于用户编写程序的制约,2.静态地址映射,在作业装入过程中进行地址变换的方式称为静态重定位或静态地址映射,0,1000,2500,5500,0,11000,12500,15500,10000,作业装入内存的情况,优点:,不需要硬件支持,缺点:,无法实现虚拟存储器,必须占用连续的内存空间;难以做到程序和数据的共享,3.动态重定位,是在程序执行期间,随着每条指令和数据访问时,自动地进行地址转换。把相对地址与程序在内存中的起始地址相加得到正确的物理地址。,0,100,400,
4、5500,.,.,一段程序所在的虚地址空间,400,VR,+,1000,BR,1000,1100,1400,.,.,重定位寄存器,虚拟空间,内存空间,动态地址重定位,动态地址重定位的实现过程:,设置基地址寄存器BR,虚地址寄存器VR将程序装入内存,且将其占用的内存区首地址BR中.在程序执行过程中,将要访问的虚地址送入VR中.地址变换机构把VR和BR的内容相加,得到实际的物理地址.,动态地址重定位的优点:,可以不连续地分配内存空间.提供了实现虚拟存储的基础,实现了虚拟存储最基本的一个保障,为今后的程序分段提供了有利的基础.有利于程序段的共享.,5.1.3 内存的分配和回收,存储管理器的分配策略有
5、以下三种:,(1)放置策略:决定主存中放置信息的区域,这是确定为进程选择一个空闲区 或若干空闲区的原则.,(2)调入策略:决定信息装入内存的时机,是在需要时调入主存.,(3)交换策略:在主存中没有任何可用的空闲区时,决定淘汰哪些信息,以便把需要的 信息装入内存.,对主存区域进行分配时,一般有2种不同的主存区域划分方式:,将主存划分成大小不等的区域将主存等分成一系列大小相等的块.,此两种模式决定了内存分配时所采取的措施或情况,5.1.4 存储保护与信息共享,现代OS采用多道程序技术,在内存当中可以驻留多个程序,为了防止被此破坏或窃取内存信息,必须由硬件(软件配合)保证每道程序只能在给定的存储区域
6、内活动,这种措施叫存储保护.,常用的存储保护手段:,(1)上下界地址寄存器,10KB,20KB,上界寄存器UR,下界寄存器LR,(a)上下界寄存器,10KB,10KB,基地址寄存器,长度寄存器,10KB,20KB,10KB,20KB,(b)基址、限长寄存器,(2)存储保护键,为每一个存储块提供一个单独的保护键.在程序状态字(PSW)在设置相应的保护键开关字段.对不同的进程赋予不同的开关代码,以和被保护的存储块中的保护键匹配.每当CPU访问主存时,都将存储块的保护键和PSW中的开关字段进行匹配,相同时允许访问,不相同时不能方法.,例:,PSW,保护位,1:要求保护0:不要求保护,5.2 分区存储
7、管理,单一连续分配:所谓单一,是指内存中只驻留一道作业.为便于地址转换,把作业连 续地存放在内存中,而不是离散地存放.,主要用在早期的单道批处理系统中,采用静态分配的方式.,优点:,方法简单,易于实现.,缺点:,仅适用于单道程序,不能处理多道.,1.固定分区法,分区管理的基本思想就是给每一个内存中的进程划分一块存储区,用以连续存放各进程的程序和数据,使各进程并发执行.,【主要特征:】,内存中分区的个数是固定的,分区的大小也是固定的。,【缺点:】,一个作业和另一个作业之间总是存在着碎片。,分区说明表,OS,进程A(6K),B(16K),进程B(25K),进程C(36K),内存,第1分区,第2分区
8、,第3分区,第4分区,3.4 动态分区法,是在作业装入到内存时,按照作业的大小去划分分区,使分区的大小正好适应作业的需要,D(120K),OS,A,OS,A,OS,A,OS,A,B,B,B,B,C,C,D,【内存分配情况:】,分区表,可用空间表,动态分区表的数据结构,40K,16K,78K,100K,24K,9K,(a)可用空间表,(b)请求表,(c)自由链,分区的分配与回收,要求Xk大小分区,取分区说明表第一项,表结束吗?,无法分配,是,否,该区空闲?,是,分区长度Xk,状态位置为“正在使用,否,否,取下一表项,返回分区号,固定分区分配算法,动态分区时的分配与回收,对于请求表中的要求内存长度
9、,分配程序从可用表或自由链中找出合适的空闲区分配给程序分配空闲区后,更新可用表或自由链进程释放内存资源时,和相邻的空闲区进行链接合并,更新可用表或自由链。,某一时刻:C执行完毕并释放内存,进程E(50K),进程F(16K)需要内存空间,OS,A(8K),B(16K),C完成(64K)空闲区,D(124K),24K空闲区,内存,0,256,进程E(50K)进程F(16K),进入内存,OS,A(8K),B(16K),E(50K),D(124K),F(16K),内存,0,256,14K空闲区,8K空闲区,OS,A(8K),B(16K),E(50K),F(16K),内存,0,256,12414138K
10、空闲区,8K空闲区,进程B(16K)进程D(124K),完成,16K空闲区,例:,A,B,C,空闲区,B完成,A,C,空闲区,空闲区,D进入,A,C,空闲区,D,E进入,A完成,E,C,空闲区,D,说明:动态分区管理模式可以把系统中一片连续的可用空间切割成多个不连续的可用空间,常见的适应算法:,1、最佳适应算法:找到满足条件最小的那个内存空间。,优点:,平均而言,只要查找一半的表格便能找到最佳适应的空闲区如果有一个空闲区的容量正好满足要求,则它必被选中。如果不存在正好满足需要的空闲区,则选中一个容量接近的空闲区。,缺点:,剩下比较小的碎片,要求:按空闲区大小从小到大的次序组成空闲区可用表或自由
11、链。在进行内存分配时,首先从空闲区表(空闲分区链)首开始查找,直到 找到第1个能满足大小要求的空闲分区为止。,优点:,只要比较第一项就能判定能否满足要求,如满足,则立即分配。分配后剩下的空闲区可能较大,可供以后使用。,缺点:,由于最大空闲区总是首先被分配,当有大作业来时,其存储空间的申请往往得不到满足。,3、最先适应算法:找到第1个满足要求的空间进行分配。,要求:需求可用表或自由链按起始地址递增的次序排列 在进行内存分配时,找到第1个满足作业大小要求的空闲区为止。,优点:,释放内存时,如果有相邻的空闲区就进行合并,使其成为一个较大的空闲区。优先利用内存低地址部分的空闲区,从而保留了高地址部分的
12、大空闲区。,缺点:,增加了查找可用空闲区的开销,2、最差适应算法:比较可用空间,找到满足条件的最大那个内存空间进行分配。,要求:按空闲区大小递减的顺序组成空闲区可用表或自由链。在进行内存分配时,首先检查空闲区的第1个分区,如果第1个空闲分区 大小小于所要求的大小,则分配失败。,4、循环最先适应算法:,要求:在进行内存分配时,不再每次从链首查找。而是从上次找到的空闲区的 下一个空闲区开始查找,直到找到第1个满足条件的空闲区。,优点:,存储空间的利用更加均衡。,缺点:,导致缺乏大的空闲区。,例:,下表给出了某系统中的空闲分区表,系统采用可变式分区存储管理策略。现有以下作业序列:96K,20K,20
13、0K。若用最先适应算法和最佳适应算法来处理这些作业序列,哪种算法可以满足该作业序列的请求,为什么?,空闲分区表,1、采用最佳适应算法,申请96K,选中的是5号分区,大小一样,从空闲表中删除5号分区申请20K时,选中1号分区,分配后还剩下12K.最后申请200K时,选中4号分区,分配后还剩下18K.,分配后的空闲分区表,2、采用最先适应算法,申请96K,选中的是4号分区,剩余122K.申请20K时,选中1号分区,分配后还剩下12K.最后申请200K时,现有的5个分区都不能满足要求。,分配后的空闲分区表,例:,在某系统中,采用固定分区分配管理方式,内存分区情况如下表所示。现有大小为1K,9K,33
14、K,121K的多个作业要求进入内存。,要求:画出它们进入内存后的空间分配情况,并说明主存浪费情况。,0,20K,28K,60K,180K,512K-1,OS,第1分区,第2分区,第3分区,第4分区,0,1K的作业,28K,60K,180K,512K-1,OS,20K,9K的作业,33K的作业,121K的作业,第1分区,第2分区,第3分区,第4分区,例:,A,B,C,碎片,解决此问题的策略:,程序浮动:程序在内存中的移动。,多重分区:一个作业可以占据几个不连续的分区,D,程序浮动的时机:,只要出现碎片就进行程序浮动。,仅当一个作业到来,任何一个可用空间都不满足,但它们的和能 够满足要求时进行程序
15、的浮动。,A,B,C,多重分区:一个作业可以占据几个不连续的分区。,A,B,C,碎片,作业,OS,A,OS,A,OS,A,OS,A,B,B,B,B,C,C,D,【内存分配情况:】,存储空间的扩充:,覆盖技术:指一个作业和其他作业,或者一个作业的若干个程序段共享内存的技术。,要解决的问题:在小的存储空间中运行大作业的问题。,覆盖技术的实现方法:,将一个大的程序划分成功能独立的若干子程序,将执行时并不要求同时装入主 存的子程序分成一组,每一组分配到同一个存储区域。,例:,程序大小24K,内存空间13K,主程序,A(子程序),B(子程序),C,D,E,G,F,H,3K,1K,4K,4K,4K,4K,
16、3K,3K,2K,主程序,A(B),4K,C(D、E、F、G),4K,H,3K,内存空间的分配情况,缺点:,程序员必须完成把一个程序划分成不同的程序段,并规定它们的执行和覆盖顺序的工作。,交换技术(对于交互式的作业而言):将暂时不需要的部分移到辅存,让出主存以调入需要的部分,交换到辅存的可以再 度被调入。,RUN,READY(A),READY(B),内存,头,尾,就绪队列,时间片到(换出),调度,(换入),5.5 页式管理,页式管理的基本原理虚拟存储管理堆栈型替换算法抖动与程序局部性,等分主存:把主存划分成相同大小的存储块,这个存储块称为页架。对于一个特定的计算机系统而言,页架大小通常是固定不
17、变的。并给各页架从零开始依次编以连续的页架号为0、1、2、3.用户逻辑地址空间的分页:把用户的逻辑地址空间(虚地址空间)划分成若干个与页架大小相同的部分,每部分称为页。并给各页从零开始依次编以连续的页号0、1、2、3逻辑地址的表示:用户的逻辑地址一般是从基地址”0“开始连续编号,即是相对地址。在分页系统中,每个虚拟地址(相对地址)用一个数对(P,D)来表示。主存分配原则:分页情况下,系统以页架为单位把主存分给作业或进程,并且给一个作业的各页架不一定是相邻或连续的。页表与页表地址寄存器:由于一个作业的各页并不全在主存中,只是将最近需要的几页放在主存中,同时这几项又不可能分散地装入各页架。页面尺寸
18、应是2的幂。,5.5.1 页式管理的基本原理,分页存储管理的地址结构,页内地址D,页号P,0,11,12,31,页号P和页内地址D按下式求得:,P=,INT,W/L,D=,W MOD L,其中:INT是整除函数,MOD是取余函数,L为页面大小,例:,系统的页面大小为1KB,设W=2230,求P和D.,P=2230/1024=2;,D=2230 MOD 1024=182;,1、页面和页架,分页存储管理就是要实现逻辑地址空间到物理地址空间的一种变换其中:W,L分别表示逻辑地址空间和页面大小。,2、地址转换机构,页地址映象表(页表):,记录了一个作业的各个页面所对应的页架.,地址转换过程:,当进程要
19、访问某个逻辑地址中的数据时,分页地址变换机构自动将逻辑地址分为页号和页内位移两部分以页号为索引检索页表,检索之前,将页号与页表长度进行比较,如果页号超过页表长度,产生越界中断,否则访问合法。将页表起始地址和页号计算出相应页表项的位置,得到该页的物理块号。将块号与逻辑地址中的页为位移拼接一起,形成主存的物理地址。,例:,设页面大小为1K,则逻辑地址为(,页表寄存器,逻辑地址,页号,块号,物理地址,越界中断,250021024452),的页号为2,页内地址为452。,由页表可知第2页对应的物理块号为8,则物理地址为(81024452)8644,作业1,0,1000,2000,作业2,作业3,作业4
20、,0,1000,2000,3000,0,1000,0,100,104,1000,1120,2000,2410,3000,页号,状态,页架,OS,0,2000,3000,3100,3104,4000,5000,.,6000,7000,8000,9000,9120,10000,ADD 1,2410,LOAD 1,1120,006802,LOAD 1,1120,ADD 1,2410,006802,006251,0,y,5,1,y,6,0,y,2,1,y,4,2,y,7,0,y,3,1,y,9,2,n,-,3,n,-,0,y,8,例:,一个3页长的进行具有进程号为0、1、2,对应的页架号4、5、9,页
21、面长度为1KB,指令为LOAD 1,2480的虚地址为200。,页表寄存器,逻辑地址,页号,页架号,物理地址,越界中断,4296,LOAD 2,2480,9648,DATA,地址转换具体过程,3、联想存储器,为了加快查页表速度,在地址变换机构中加入一组高速寄存器(8个或16个)这些寄存器连同管理它们的硬件构成了一个容量较小的存储器,称之为高速联想存储器,也称块表。,页表寄存器,逻辑地址,页号,页架号,物理地址,越界中断,地址转换具体过程,块表,4、页面尺寸大小的确定,为了加快查页表速度,在地址变换机构中加入一组高速寄存器(8个或16个)这些寄存器连同管理它们的硬件构成了一个容量较小的存储器,称
22、之为高速联想存储器,也称块表。,例:,设内存为M,作业平均尺寸为J,一个页表项占1个单位,问:最佳页面尺寸P=?,例:,设有一页式存储管理系统,向用户提供的逻辑地址空间最大为16页,每页2048字节。内存总共有8个存储块。,问:逻辑地址至少应为多少位?内存空间有多大?,例:,设有一页式存储管理系统,某作业J的逻辑地址空间为4页(每页2048字节),且已知该作业的页表如下:,求出有效逻辑地址4865所对应的物理地址。,页号,页架号,5.5.2 虚拟存储管理,1、虚拟存储管理应该解决的问题:,把哪部分装入内存何时把页面装入装入内存什么位置当内存没有空间时淘汰哪些页面,2、实现的策略:,拿来策略:,
23、就是程序执行过程当中,发现内存当中缺哪页就调入那页。,页面装入时机策略:,预调页策略何请求调页策略,放置策略:,哪有地方,就放在那。,3、对于页面的处理需要考虑的问题,每个虚页号不仅对应一个页架号,还增设一个该页是否在主存的中断位何该页在外存 中的副本起始地址。,当内存中设有可以利用的页架时,根据一定的策略从内存中选择一个页面,把它置换到外存,称为页面置换算法。,4、页面置换策略:,在页表当中适当的加入“是否被修改”和“访问频率”标志位。,先进先出算法(FIFO):总是淘汰那些驻留在内存当中时机最长的页面。,最近最久未用置换算法(LRU):当需要置换一页时,选择在最近一段时机 最久未适应的页面
24、予以淘汰。,最近没有使用页面淘汰算法(NRU):需要在页表中设一“引用位”,当页面被访问时,该位由硬件自动置位“1”。,最佳淘汰算法(OPT):淘汰今后将永远也不使用的页面,或者是长时机不使用的页面。,例:,在一个请求分页系统中,假定系统分给一个作业的物理块为3,并且此作业的页面走向为2,3,2,1,5,2,4,5,3,2,5,2。,用FIFO,LRU,OPT页面置换算法计算缺页次数。,(1)FIFO算法,(2)LRU算法,(3)OPT算法,例:,有一请求分页存储管理系统,页面大小为每页100字节,若在程序执行时内存中只要一个存储块用来存放数组信息。有一个5050的整型数组按行连续存放,每个整
25、数占2个字节,将数组初始化为“0”的程序如下:,问:该程序执行时产生多少次缺页中断?,int a5050;int I,j;for(i=0;i50;i+)for(j=0;j50;j+)aij=0;,例:,有一矩阵,int a100100;按先行后列次序存储。在一虚存系统中,采用LRU淘汰算法,一个进程有3页内存空间,每页可以存放200个整数。其中第1页存放程序,且假定程序已在内存。,分别就程序A和程序B的执行过程计算缺页次数。,int a100100;int i,j;for(i=0;i100;i+)for(j=0;j100;j+)aij=0;,程序A:,int a100100;int i,j;f
26、or(i=0;i100;i+)for(j=0;j100;j+)aji=0;,程序B:,例:,在一个请求分页系统中,假定系统分给一个作业的物理块为3,并且作业执行序列为1,2,5,1,2,3,4,5。,用FIFO页面置换算法计算缺页次数。,FIFO算法,现序列该为:1,2,3,4,1,2,5,1,2,3,4,5,FIFO算法,*,*,*,*,*,*,*,*,*,*,*,*,*,*,*,*,现将内存空间扩大到4个页架,*,*,*,*,*,此题说明的问题:有些问题的想法跟人们的想法往往是不一致的。,5.5.3 堆栈型替换算法,设A是长度为L的任何页面地址流,t为已经处理过的(t-1)个页面的时间点,
27、n 为分配给该地址流的实存页架数,Bt(n)表示在t时间点,n个页架的实存中的页面集,Lt 表示到t 时已经遇到过的地址流中相异页的页数,如果页面置换算法具有下列包含性:,n,Lt时,,Bt(n),Bt(n+1),n,Lt时,,Bt(n),=,Bt(n+1),则称此置换是堆栈型的。,说明:A是一个作业,L是页面的长度,t为时间点,指的是当执行到t这个时刻已经处理 了(t-1)个页面。n为分配给作业A的实际内存的页架数。Bt(n)指的是:在t这个时 间点上,给它分配的n个页架当中在t这个时刻保存的页面的集合。Lt表示经过t 这个时刻,已经处理过的和遇到过的不同的页面的个数。,例:,对下列页地址流
28、A=1,2,3,4,1,2,5,1,2,3,4,5.,*,*,*,*,*,*,*,*,*,*,*,*,n=3,n=4,*,*,*,*,*,*,*,*,*,*,*,*,=,堆栈型算法说明的问题:,在任何时刻,堆栈型算法都遵从这样一个特定:当内存扩充之后,扩充之后保存的页面和扩充之前保存的页面它们之间存在子集的关系。,栈式算法强调的是:,当内存中有n个和(n+1)个页架的时候,在任何时刻t,这2个页架在内存当中页面的集合存在蕴含关系,凡是满足这样的蕴含关系,则称为栈式算法。,St(1),St(2),St(3),St(4),St(5),St(6),n=1,页地址流A,n=2,n=3,n=4,n=5,
29、时间t,命中,命中,命中,命中,命中,命中,命中,命中,命中,命中,命中,命中,命中,命中,命中,命中,命中,命中,命中,命中,5.6 段式管理,段式存储管理的基本思想段式存储管理的地址转换段的共享与保护段式管理的特点,5.6.1 段式存储管理的基本思想,段式存储管理中以段为单位分配内存,每段分配一个连续的内存区.但各段之间不要求连续.内存的分配和回收与动态分区分配类似.段是一个逻辑概念,就是用户在编写程序的时候你就可以划分成段。,分段地址空间示例:,主程序,0,1K,分段A,子程序,0,600,分段B,子程序,0,400,分段C,由于段式存储管理系统中作业的地址空间是二维的,因此地址结构包括
30、2部分:段号和段内位移。,段号S,位移量W,0,11,12,31,段的中断处理过程算法如下:,算法FOLD(新段X的长度)BEGIN IF(内存中的空闲区 X)IF(内存中空闲区总和 X)按FIFO、LRU算法淘汰老段;ELSE 合并空闲区形成不小于X段的空闲区;为X段分配内存空闲区;将X段调入内存并改写段表;RETURN;END,5.6.2 段式存储管理的地址转换,在段式管理地址变换过程中,和页式变换基本相同,先要为运行的进程建立一个段表,段式存储变换的具体过程,段表地址,段表地址寄存器,4404,在段式系统中,分段的共享是通过2个作业的段表中相应表目都指向被共享部分的同一物理副本来实现的。
31、大多数实现共享的系统中,程序被分成过程区和数据区。,不能修改的过程称为纯过程或可重入过程,这样的过程和不能修改的数据是可以共享的,而可修改的程序和数据则不能共享。,5.6.3 段的共享与保护,在段式系统中,分段的共享是通过2个作业的段表中相应表目都指向被共享部分的同一个物理副本来实现的。大多数实现共享的系统中,程序被分成过程区和数据区。,不能修改的过程称为纯过程或可重入过程,这样的过程和不能修改的数据是可以共享的,而可修改的程序和数据则不能共享。,5.6.4 段式管理的特点,优点:,提供了内外统一管理的虚存实现方案段式虚拟每次交换的是一个程序段或数据段。在段式管理中,段长可根据需要动态地调整。
32、,缺点:,要求更多的硬件支持,提高了机器的成本。由于在内存空闲区管理方式上与分区管理相同,因而存在碎片问题。每段的长度受内存可用空闲区大小的限制。若淘汰算法选择不当,也有可能产生抖动。,页式管理与 段式管理的主要区别:,页是信息的物理单位,分页是为了实现非连续分配,以便解决内存碎片问题。段是信息的逻辑单位,它含有一组意义相对完整的信息。分段的目的是为了更好实现共享满足用户的需要。页的大小固定且由系统确定,将逻辑地址划分成页号和页内地址是由机器硬件实现的。而段的长度却不固定,决定于用户所编写的程序。通常由编译程序再对源程序进行编译时根据信息的性质来划分。分页的作业地址空间是一维的,分段的地址空间
33、是二维的。,5.7 段页式存储管理,基本思想:把段式和页式二者的优点都结合起来,然后统一地进行考虑。一个逻辑地 址用3个参数表示:段号S,页号P,页内地址偏移量D.,为指出运行进程的段表地址,系统中有一个段表地址寄存器来指出进程的段表起始地址和段表长度。,段表寄存器,虚地址V(S,P,D),段号,页表长度,物理地址,越界中断,页表始地址,页号,页架号,段页式存储管理中地址转换,转换过程:,地址转换硬件将段表寄存器内容与指定地址场中的段号S按段表的表目进行适当的移位后相加,得到欲访问段S在该进程的段表中的段表项。从该表的表目中得到该段的页表起始地址,并将其与地址场中的页号P相加后得到欲访问页P在
34、该段的页表中的表目入口地址。从该页表表目中取出其对应的页架号与指令地址场中的页内地址D拼装形成绝对地址。,若运行过程访问虚地址V(S,P,D),在没有联想寄存器下,地址转换过程如下:,段页式存储管理的优缺点:,优点:(1)提供二维地址空间,有利于内存共享。(2)便于段动态扩充,有利于实现动态数据结构。(3)对于大型软件,只需在运行中动态链接需要的段。(4)把零头转换为页内零头,提高了存储空间的利用率。,缺点:(1)复杂性和开销增加了。(2)需要的硬件以及占用的内存页需要增加。(3)如果不采用联想存储器,就会大大降低内存访问效率。,例:,有一段页式系统,段表和页表存放在主存中。(1)如果对主存的
35、一次存取需要1.5微秒,问:实现一次页面访问的存取时间 是多少?(2)如果系统有快表,平均命中率为85。当页表项在快表中时,其查找时 间忽略不计,问:此时的存取时间是多少?,程序的局部性:是指在一段时间内程序仅仅集中访问某一部分地址空间,具体 包括时间局部性和空间局部性,5.5.4 抖动与程序局部性,缺页率:设进程访问内存成功的次数为S,缺页的次数为F,则总访问次数为A,缺页率W=F/A;,抖动:指页面在内存与外存字节频繁地换入换出,以致于系统用于调度页面所需要的 时间比进程实际运行作业所占用的时间还要多。,1、抖动的原因,抖动是由于页的缺页率很高而引起的,页的缺页率高的原因主要有下面两点:,分配给进程的物理页架数过少页面置换算法不合理程序结构,2、抖动的处理,增加分给进程的物理页架数改进页面置换算法用户编写程序时也要充分考虑程序的局部性特征,工作集:在某一个时间范围之内,进程实际上要访问的页的集合。所以把一个运行在t-w到t 这个时间间隔内所访问的页的集合称为该进程在时间t的工作集,记为W(t,w),并称 w为“工作集窗口尺寸”。,工作集,.,最少页架数,(1)一个指令,(2)间接字,页式存储管理的优点:,提高了系统资源(内存)的利用率,解决了固定、可变分区中的碎片问题。引入虚拟存储思想之后,能够实现存储器的扩充。,页式存储管理的缺点:,共享内存问题。,