赞
踩
逻辑地址映射到物理地址,当我们给程序分配物理地址空间时,会给予一个程序随机连续的一段物理地址空间。那么就会出现内存碎片的问题!
上述白色部分就是外部碎片
定义:在分配单元间的未使用内存
定义:在分配单元中的未使用内存
有了碎片,就降低了内存使用率,这个时候内存分配的方法选择就很重要了。
使用该算法进行内存分配时,按地址排序的空闲块列表
,从空闲分区链首开始查找,直至找到一个能满足其大小需求的空闲分区为止
;然后再按照作业的大小
,从该分区中划
出一块内存分配给请求者,余下
的空闲分区仍留在空闲分区链中。
该算法倾向于使用内存中低地址部分的空闲分区
,在高地址部分的空闲分区非常少被利用,从而保留了
高地址部分的大空闲区。显然为以后到达的大作业分配大的内存空间创造了条件。缺点在于低址部分不断被划分,留下许多难以利用、非常小的空闲区
,而每次查找又都从低址部分开始,这无疑会增加查找的开销
。
碎片重分配需要检查,看是否有自由分区能合并于相邻的空闲分区,若有,然后调整空闲块列表
优势:
劣势:
最优适配算法是从全部空闲区中找出能满足作业要求的
、且大小最小
的空闲分区的一种计算方法,这种方法能使碎片尽量小
。
优势:
劣势:
为了避免有太多微小的碎片,最差适配算法是从全部空闲区中找出能满足作业要求的
、且最大
的空闲分区的一种计算方法。
优势:
劣势:
(1)压缩式
将程序拷贝到其他连续的地址空间里去
,一般在程序停止时,进行拷贝,在内存中拷贝开销也是非常大的,如下图所示
(2)交换式
采用换入换出
的方式,将硬盘当作后备
这种内存已经使用满了,压缩式已经不能够使用了,我们只能把其中一个未运行
的程序放入硬盘中,腾出空间给需要运行的程序。粒度是以单个程序大小作为单位的
,如果大块的程序的换入换出开销也挺大的。当然p4的数据并没有丢失
,只是放到了硬盘,需要运行时,又从硬盘调进内存
。
选择那个程序换入换出,也是需要一个好的算法来支持的。
从代码
来看,有主程序、子程序、共享库形成了代码不同的分段
;从数据存储
来看,有堆栈段、共享数据段。
将各个段进行识别分离
,这样更有效的进行管理
,这就是分段的目的。因为我们需要映射到物理地址空间,可以是不连续的
,就需要一种映射的机制。
一个2维的二元组(s,addr)
段表:里面存的是逻辑段号到物理段号的映射,以及段长的限制
段号:决定了看段表中的哪一项
段偏移:段偏移会和段长的限制比较大小,小了,才是合法的,才能允许访问内存。
段基址+段偏移得到物理地址
一个2维的二元组(p,o)
注:
页寄存器
定义了DMA缓冲区的起始位置所在物理页的基地址,即页号
。页寄存器有点类似于PC中的段基址寄存器分段的段长是可变的,分页的页的大小是固定的。
帧
,大小是2的幂
;eg:…512,4096,8192页
,大小是2的幂
;eg:…512,4096,8192注:页和帧都是大小必须是相同的。
(3)物理地址计算实例
根据页号找到页表项,然后得到帧号,帧号*帧大小+页内偏移就得到了物理地址。
逻辑地址空间是大于物理地址空间的,所以不可能所有页都有对应的帧,这个需要硬盘虚拟内存技术来解决!
第一个求逻辑地址为(4,0)的物理地址:
我们可以根据页号4,判断页表项为第一项,其存在位为0,故此页在内存中不存在,所以会报内存异常。
第二个求逻辑地址为(3,1023)的物理地址:
我们可以根据页号3,判断页表项为第二项,其存在位为1,故此页在内存中存在,且帧号为4,所以物理地址为(4,1023)。
注:因为页表可能非常大,所以不能放在cpu或者缓存中,因此页表是处于内存中的。
所以访问一个内存单元需要两次内存访问
:
接下来将从时间
和空间
提升访问速度。
TLB特点:
如果存在位为0,那么只查询一级页表就够了。加快了速度。
我们都知道逻辑地址空间是大于物理地址的,很多查询不存在,我们能不能不建立页表和逻辑地址空间大小相对应,而是让页表与物理地址空间大小相对应?
这个就是反向页表,根据帧号查询页号。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。