码迷,mamicode.com
首页 > 其他好文 > 详细

操作系统-内存换出

时间:2020-04-04 22:41:41      阅读:88      评论:0      收藏:0      [点我收藏+]

标签:get   访问   进程   扫描   虚拟   接下来   image   系统   页面   

有换入就应该有换出

1. get_free_page ?

技术图片

2. FIFO页面置换

技术图片

D换A不合适,因为接下来A也要进行使用,所以应该换最近用不到的C合适

3. MIN页面置换

技术图片

4. LRU页面置换

技术图片

5. LRU的准确实现,用时间戳

A是第一个时刻使用,B是第二个时刻使用,C是第三个时刻使用,然后又是A第四个时刻使用,然后是B第五个时刻使用,此时对应的是A:4、B:5、C:3

接下来D来了,看哪一个数值最小就换出,所以D换入为6,C换出

接下来过程类似

技术图片

6. LRU准确实现,用页码栈

技术图片

7. LRU近似实现-将时间计数变为是和否

每次访问一页时,硬件自动设置该为1

当选择淘汰页的时候,扫描该位,发现是1就清0,并向下继续扫描,当发现是0的时候就淘汰

技术图片

8. Clock算法的分析与改造

也就是缺页很少的情况下,每个页都访问过,所有的R=1,此时再淘汰页的时候需要扫描一圈,把R=1置换为R=0,然后淘汰当前指针指的那一页,这样就退化成了FIFO

所以再引入一个指针,速度快的用于清除R位

技术图片
技术图片

9. 小结

实现换入换出为了实现虚拟内存,

实现虚拟内存为了实现段页结合,

实现段页结合为了实现操作系统管理内存

实现管理内存为了实现程序能够载入执行

程序执行就是实现进程

技术图片

操作系统-内存换出

标签:get   访问   进程   扫描   虚拟   接下来   image   系统   页面   

原文地址:https://www.cnblogs.com/mengd/p/12634480.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!