虚拟内存之页面置换算法

内存空间不够,OS将内存中暂时用不到的信息换出到外存。但页面的换入/出需要磁盘I/O,系统开销较大。页面置换算法要更少的缺页率。

一、最佳置换(OPT)-optimal

1.思想

每次选择淘汰以后永不使用、在最长时间内不再被访问的页面,以此保证最低的缺页率。

2.实现

如果有可用空闲内存块,缺页不必进行页面置换,直接调入内存即可。

如果没有可用空闲内存块,往右找最远的页面即是要被淘汰的页面,将其换出

2.计算

缺页中断次数=内存块数+页面置换次数

缺页率=缺页中断次数/总访问次数

3.特点

实现前提是操作系统会预先知道访问页面的序列,实际是无法实现的,是一种理想化算法。

二、先进先出置换算法(FIFO)

1.思想

每次选择淘汰早出最早进入内存的页面,以此保证最低的缺页率。

2.实现

按调入内存顺序将页面排成一个队列。

如果有可用空闲内存块,缺页不必进行页面置换,直接将其插入队列队尾即可。

如果没有可用空闲内存块,淘汰队头页面,将新调入页面插入队尾

3.特点

当为进程分配的物理块数增大时,缺页次数也会增加。

盲目淘汰最先进入的页面,而未考虑其访问次数,算法性能差。

三、最近最久未使用置换算法(LRU)-least recently used

1.思想

每次选择淘汰最近最久未使用的页面,以此保证最低的缺页率。

2.实现

为每个页面建一个页表项,并用访问字段记录该页面由上次被访问以来所经历的时间。

如果有可用空闲内存块,缺页不必进行页面置换,直接调入内存即可。

如果没有可用空闲内存块,淘汰页面中t值最大的页面,将其换出。(即往左找最远的页面即为要淘汰的页面)

3.特点

需要专门硬件支持,实现困难,开销大

四、时钟置换算法(CLOCK)

即最近未用算法(NRU, not recently used)

1.思想

每次选择淘汰最近未用的页面,以此保证最低的缺页率。

2.实现

为每个页面设置一个访问位,再将内存中页面通过指针链接成一个循环队列。被访问时访问位置为1。

按可用空闲内存块,将页面调入并链接成一个循环队列,访问位均是1.

如果没有可用空闲内存块,淘汰访问位为0的页面,将其换出;如果访问位都是1,将其置为0,暂不换出,开始第二轮扫描时,淘汰访问位为0的页面

3.特点

只考虑到页面最近是否被访问,未考虑淘汰页面的状态(是否被修改)进行置换

3.改进

优先淘汰未被访问未被修改过(0,0) ------> (0,1)的页面无需执行I/O操作写回外存。增加一个修改位,0-未被修改,1-已被修改。

用(访问位,修改位)表示各页面状态,进行置换。

相关推荐
汽车电子嵌入式2 个月前
【OS基础】符合AUTOSAR标准的RTAOS-Alarms详解
autosar·os·alarm
计算机学无涯2 个月前
操作系统微助教题库(组卷)
操作系统·os
Voltline3 个月前
HawkEye—高效、细粒度的大页管理算法
linux·算法·操作系统·内存管理·os·大页内存管理·透明大页
ThinkPet3 个月前
笔记-用Python脚本启停JAR程序
java·python·jar·signal·os·subprocess
逸埃4 个月前
[AutoSar]BSW_ OS CORE, Physical core,EcuC core,EcuC partition,OSApplication的关系
autosar·os·bsw·ecuc
长孤秋落5 个月前
Python模块百科_操作系统接口_os【三】
python·操作系统·模块·os·多平台
自律即自由w5 个月前
内存管理 -----分段分页
内存管理·os·分页分段
肆十二6 个月前
Python中os模块的常用方法和示例
开发语言·python·os
老马啸西风6 个月前
操作系统-01-Mac 苹果操作系统 Brew /端口占用
macos·操作系统·apple·os
逸埃7 个月前
[AutoSar]BSW_OS 05 Autosar OS_Alarms
autosar·os·bsw