虚拟存储器—页面置换算法

虚拟存储器—页面置换算法

一、最佳页面置换算法 OPT

目前是理想化的算法,是无法实现的。

选择内存中被淘汰页面的条件:

重点在于以后,看物理块中哪一个页号在以后是最后才被访问使用的或者不使用的

例题:给出某进程所分配到的物理块数量,以及接下来所要使用的页面号顺序,让你使用该算法画出置换图。

7772
000
11
发生置换

发生第一次置换的详细分析:

此时要访问页号2,但是3个物理块已经满了,所以发生缺页中断,使用最佳页面置换算法把其中一个替换掉。

此时在未使用的页号顺序里面查看判断,看物理块中的3个页号中,哪一个是最后才访问使用的。

在这顺序里可以知道,7是第18次页面访问时才使用,0是第5次页面访问时使用,1是第14次页面访问时使用。所以我们要淘汰最后一个才使用的页号7,把页号2替换页号7,物理块里面就变为了2 0 1。


二、先进先出置换算法 FIFO

选择内存中被淘汰页面的条件:

看物理块中哪一个页号是第一个进来的,即驻留时间最长,就淘汰该页号。是根据页面调入内存的时间做决策的。

发生第一次置换的详细分析:

上述例题中,当要访问使用页号2时,查看物理块中701中哪一个是第一个进来的就要最先淘汰出去,所以叫作先进先出。

可以从页号顺序得知7是最先进入物理块的,所以淘汰页号7。

此时物理块变为2 0 1 。


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

选择内存中被淘汰页面的条件:

是根据页面调入内存后的使用情况做决策的。

发生第一次置换的详细分析:


四、最少使用置换算法

选择内存中被淘汰页面的条件:

最近时期使用最少的页面作为淘汰页面,即看以后的页面访问顺序中,哪一个页面的访问次数最少就作为淘汰页面。

五、Clock置换算法

选择内存中被淘汰页面的条件:

额外条件:

每页设置一个访问位,并将内存中的所有页面链接成一个循环队列。

当某一页被访问时,访问位置为1。

未被访问时,访问位置为0。

淘汰条件:

只需要看访问位是否为0,是0就表示该页最近都未被访问使用过,就淘汰该页。

如果是1,表示该页近期被访问使用过,此时重新将访问位置为0。

改进型Clock置换算法:

在Clock置换算法的基础上增加修改位。

使用访问位、修改位同时决定要被淘汰的页面。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值