Linux——页面置换算法(OPT、FIFO、LRU的实现与比较)

目录

 1、  实验题目

   2、实验要求

(1)指令的地址按下述原则生成

(2)具体的实施方法

(3)将指令序列变换为页地址流

3、算法实现参考代码:

 4、运行结果

 5、算法比较

 1、  实验题目

设计一个虚拟存储区和内存工作区,并使用下述算法计算访问命中率。

1、最佳淘汰算法(OPT)

2、先进先出的算法(FIFO)

3、最近最久未使用算法(LRU)

4、最不经常使用算法(LFU)

5、最近未使用算法(NUR)

命中率=1-(页面失效次数/页地址流长度)

   2、实验要求

  本实验的程序设计首先用srand(  )和rand( )函数定义和产生指令序列,然后将指令序列变换成相应的页地址流,并针对不同的算法计算出相应的命中率。

(1)指令的地址按下述原则生成

通过随机数产生一个指令序列,共320条指令。

   A:50%的指令是顺序执行的

   B:25%的指令是均匀分布在前地址部分  

   C:25%的指令是均匀分布在后地址部分

(2)具体的实施方法

  A:在[0,319]的指令地址之间随机选取一起点m

  B:顺序执行一条指令,即执行地址为m+1的指令

  C:在前地址[0,m+1]中随机选取一条指令并执行,该指令的地址为m’

  D:顺序执行一条指令,其地址为m’+1

  E:在后地址[m’+2,319]中随机选取一条指令并执行

  F:重复步骤A-E,直到320次指令

(3)将指令序列变换为页地址流

   设:页面大小为1K;

   用户内存容量4页到32页;

   用户虚存容量为32K。

   在用户虚存中,按每K存放10条指令排列虚存地址,即320条指令在虚存中的存放方式为:

   第 0 条-第 9 条指令为第0页(对应虚存地址为[0,9])

   第10条-第19条指令为第1页(对应虚存地址为[10,19])

………………………………

   第310条-第319条指令为第31页(对应虚存地址为[310,319])

   按以上方式,用户指令可组成32页。

  • 5
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Sweep-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值