zoukankan      html  css  js  c++  java
  • 虚拟存储器2

    最佳( Optimal)置换算法

     最佳置换算法足由Belady于1966年提出的一种理论上的算法。其所选择的被淘汰页 面将是以后永不使用的,或许是在最长(未来)时间内不再被访问的页面。采用最佳置换算 法通常可保证获得最低的缺页率。但由于人们目前还无法预知,一个进程在内存的若干个 页面中,哪一个页面是未来最长时间内不再被访问的,因而该算法是无法实现的,但可以 利用该算法去评价其它算法。

    现举例说明如下。 假定系统为某进程分配了三个物理块,并考虑有以下的页面号引用:

     7,0, 1, 2,0,3, 0, 4, 2, 3, 0,3, 2, 1, 2,0, 1, 7, 0, 1

    进程运行时,先将7, 0, 1三个页面装入内存以后,当进程要访问页面2时,将会产生缺页中断。此时OS根据最佳置换算法将选择页面7予以淘汰。这是因为页面0将作为第5个被 访问的页面,页面1是第14个被访问的页面,而页面7则要在第18次页面访问时才需调入。下次访问页面0时,因它已在内存而不必产生缺页中断。当进程访问页面3时,又将引起页 面1被淘汰;因为,它在现有的1,2, 0三个页面中,将是以后最晚才被访问的。图5-3示 出了采用最佳置换算法时的置换图。由图可看出,采用最佳置换算法发生了6次页面置换。

     

    最少使用 (Least Frequently Used, LFU)置换算法 

    在采用LFU算法时,应为在内存中的每个页面设置一个移位寄存器,来记录该页面 被访问的频率。该置换算法选择在最近时期使用最少的页面作为淘汰页。由于存储器具有 较高的访问速度,例如100ns,在1ms时间内可能对某页面连续访问成千上万次,因此, 直接利用计数器来记录某页被访问的次数是不现实的,只能采用较大的时间间隔来记录对 存储器某页的访问。在敁少使用®换算法中采用了移位寄存器方式。毎次访问某页时,便将该移位寄存器的最高位置1,再每隔一定时间(例如100 ms)右移一次。这样,在最近一段 时间使用最少的页面将是二进制最小的页。 LFU置换算法的页面访问图,与LRU置换算法的 访问图完全相同;或者说,利用这样一套硬件既可实现LRU算法,又可实现LFU算法。 应该指出,这种算法并不能真正反映出页面的使用情况,因为在每一时间间隔内,只是用 寄存器的一位来记录页的使用情况,因此,在该时间间隔内,对某页访问一次和访问1000 次是完全等效的。

    Clock置换算法

    1. 简单的Clock置换算法

    当利用简单Clock算法时,只需为每页设質一位访问位,再将内存中的所有页面都通过链接指针链接成一个循环队列。当某页被访问时,其访问位被置 1。置换算法在选择一 页淘汰时,只需检査页的访问位。如果是0,就选择该页换出;若为1,则重新将它置0, 暂不换出,给予该页第二次驻留内存的机会,再按照FIFO算法检査下一个页面。当检查 到队列中的最后一个页面时,若其访问位仍为1,则再返回到队首去检査第一个页面。图 5-8示出了该算法的流程和示例。由于该算法是循环地检杳各页面的使用情况,故称为Clock 算法。但因该算法只有一位访问位,只能用它表示该页是否已经使用过,而置换时是将未 使用过的页面换出去,故又把该算法称为最近未用算法或NRU算法。

     

    1. 改进型Clock置换算法

    在将一个页而换出时,如果该页已被修改过,便须将该页重新写回到磁盘上;但如果 该页未被修改过,则不必将它拷回磁盘。换而言之,对修改过的页面,在换出时所付出 的开销比未修改过的页面大,或者说, S换代价大。在改进型 Clock算法中,除须考虑页面的使用愔况外,还须再增加一个因索——S换代价。这样,选择页面换出时,既要是未使用过的页面,又要是未被修改过的页面。把同时满足这两个条件的页面作为首选淘汰的页面。由访问位A和修改位M可以组合成下面四种类型的页面:

    1类(A=0, M=0):表示该页最近既未被访问,又未被修改,是最佳淘汰页。

    2类(A=0, M=丨):表示该页最近未被访问,但已被修改,并不是很好的淘汰页。

    3类(A=l,M=0):表示最近己被访问,怛未被修改,该页有可能再被访问。

    4类(A=l,M=丨):表示最近已被访问且被修改,该页可能再被访问。

    优先级:00-->01-->10-->11

     

    LRU置换算法的硬件支持

    1. 寄存器

    为了记录某进程在内存中各个页的使用情况,须为每个在内存中的页面配置一个移位寄存器,可表示为R=,

    当进程访问某物理块时,要将相应寄存器的位置成1。此时,定时信号将每隔一 定时间(例如100 ms)将寄存器右移一位。如果我们把n位寄存器的数看作是一个整数,那么,具有最小数值的寄存器所对应的页面,就是最近最久未使用的页面。图5-6示出了某 进程在内存中具有8个页面、为每个内存页面配—个8位寄存器时的LRU访问情况。这 里,把8个内存页面的序号分别定为1〜8.由图可以看出,第3个内存页面的R值最小, 当发生缺页时,应首先将它置换出去。

     

     

    利用了一个特殊的栈保存当前使用的各个页面的页面号,每当进程访问某页面时,便将该页面的页面号从栈中移除,将它压入栈顶,因此,栈顶始终是最新被访问的页面编号,栈底是最久未使用页面的编号。

     

    5.4 “抖动”与工作集

    1.抖动

    频繁的发生缺页现象。

    2.工作集

    工作集是指在某段时间间隔 ∆ 里,进程实际要访问的页面的集合。

    1. 预防方法

    (1)局部置换

    (2)引入工作集

    (3)“L=S”

    (4)挂起几个进程

     

    5.5 请求分段存储管理方式

    1.段表项

     

    2.地址变换

     

    1. 分段的共享和保护
    2. 基于段表
    3. 保护

    (1)越界检查

    (2)存取控制检查

    (3)环保护机构

     

  • 相关阅读:
    A1039 Course List for Student (25 分)
    A1101 Quick Sort (25 分)
    日常笔记6C++标准模板库(STL)用法介绍实例
    A1093 Count PAT's (25 分)
    A1029 Median (25 分)
    A1089 Insert or Merge (25 分)
    A1044 Shopping in Mars (25 分)
    js 验证
    根据string获取对应类型的对应属性
    HTML 只能输入数字
  • 原文地址:https://www.cnblogs.com/giaogiaogiao/p/12696635.html
Copyright © 2011-2022 走看看