操作系统_Lab4_页面置换算法

该博客介绍了操作系统中常见的页面置换算法,包括最佳适应、最近最久未使用、先进先出、改进型Clock和页面缓冲算法。通过模拟实现和性能对比,分析了不同算法的缺页率和适用场景,实验表明页面缓冲算法和最佳适应算法表现最优。
摘要由CSDN通过智能技术生成

目录

1. 实验目的及基本要求

2. 基础知识

3. 实验内容

3.1 概要设计

3.2 详细设计

3.2.1 程序实现流程

3.2.2 页面的结构设计

3.2.3 随机序列的生成

3.2.4 最佳适应算法(OPT)

3.2.5 最近最久未使用置换算法(LRU)

3.2.6  先进先出置换算法(FIFO)

3.2.7 改进型Clock置换算法

3.2.8 页面缓冲算法(PBA)

3.3 不同算法对比

4. 实验总结


1. 实验目的及基本要求

设计和实现最佳置换算法、先进先出置换算法、最近最久未使用置换算法、页面缓冲置换算法

通过页面访问序列随机发生器实现对上述算法的测试及性能比较。

2. 基础知识

1. 请求分页虚拟内存管理

建立在基本分页基础上的,为了能支持虚拟存储器功能,而增加了请求调页功能和置换功能。

2. 工作集

多数程序都显示出高度的局部性,也就是说,在一个时间段内,一组页面被反复引用。这组被反复引用的页面随着时间的推移,其成员也会发生变化。有时这种变化是剧烈的,有时这种变化则是渐进的。我们把这组页面的集合称为工作集

3. 缺页率

缺页中断次数/总的页面访问次数

4. 最佳置换算法(OPT)

Ø选择永不使用或是在最长时间内不再被访问(即距现在最长时间才会被访问)的页面淘汰出内存

Ø理想化算法,具有最好性能(对于固定分配页面方式,本法可保证获得最低的缺页率),但实际上却难于实现,故主要用于算法评价参照

5. 先进先出置换算法(FIFO)

Ø选择最先进入内存即在内存驻留时间最久的页面换出到外存

Ø进程已调入内存的页面按进入先后次序链接成一个队列,并设置替换指针以指向最老页面

Ø简单直观,但不符合进程实际运行规律,性能较差,故实际应用极少

6. 最近最久未使用置换算法(LRU)

Ø以“最近的过去”作为“最近的将来”的近似,选择最近一段时间最长时间未被访问的页面淘汰出内存

Ø适用于各种类型的程序,性能较好,但需要较多的硬件支持

7. 改进型Clock置换算法

Ø① 从查寻指针当前位置起扫描内存分页循环队列,选择A=0M=0的第一个页面淘汰;若未找到,转②

   ② 开始第二轮扫描,选择A=0M=1的第一个页面淘汰,同时将经过的所有页面访问位置0;若不能找到,转①

Ø与简单Clock算法相比,可减少磁盘的I/O操作次数,但淘汰页的选择可能经历多次扫描,故实现算法自身的开销增大

8. 页面缓冲算法(PBA)

Ø设立空闲页面链表和已修改页面链表

Ø采用可变分配和基于先进先出的局部置换策略,并规定被淘汰页先不做物理移动,而是依据是否修改分别挂到空闲页面链表已修改页面链表的末尾

Ø空闲页面链表同时用于物理块分配

Ø当已修改页面链表达到一定长度如Z个页面时,一起将所有已修改页面写回磁盘,故可显著减少磁盘I/O操作次数

3. 实验内容

前提:1)模拟的虚拟内存的地址为16位,页面大小为1K,模拟的物理内存有32K

           2)页表用整数数组或结构数组来表示,页面访问序列串是一个整数序列,整数的取值范围为0N - 1

           3)页面访问序列串中的每个元素p表示对页面p的一次访问

           4)符合局部访问特性的随机生成算法

  1. 确定虚拟内存的尺寸N,工作集的起始位置p,工作集中包含的页数e,工作集移动率m(每处理m个页面访问则将起始位置p +1),以及一个范围在0和1之间的值t
  2. 生成m个取值范围在p和p + e间的随机数,并记录到页面访问序列串中
  3. 生成一个随机数r,0 ≤ r ≤ 1
  4. 如果r < t,则为p生成一个新值,否则p = (p + 1) mod N
  5. 如果想继续加大页面访问序列串的长度,请返回第2步,否则结束

3.1 概要设计

根据要求,本实验大致流程如下::

1)设定页面初始的结构表示

2)利用符合局部访问特性的随机生成算法生成实验所需要的页面访问序列

3)针对生成的访问序列,编写不同置换算法实现

4)计算出不同算法缺页率,多次测试以比较算法优劣

根据以上流程,可将本次实验分为四个模块:

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值