页面置换算法的模拟实现

一. 实验内容

1. 假设某一个进程,在运行过程中需要访问的内容依次在320个地址中。为了模拟产生320个地址的值。首先实现在main函数中调用下面的函数随机产生320个地址的地址序列。

#include<unistd.h>

void randarray(int a[],int k)

{   int i;

    float s;

    srand(getpid());

    s=(float)319.0*(rand()%32767)/32767.0+1.0;

    for(i=0;i<k;i+=4)

    {

        a[i]=(int)s+512;

        a[i+1]=a[i]+513;

        a[i+2]=(int)((float)a[i]*(rand()%32767)/32767.0)+512;

        a[i+3]=a[i+2]+1;

        s=(float)(rand()%32767)*(318.0-a[i+2])/32767.0+a[i+2]+2.0+512;

    }

}

其中:

a[ ]:存放产生的320个地址。

k:产生地址的数目,在本实验中取320。

2.  假定页面大小是512字节。(提示:从上面randarray函数获得的是地址,页号=地址/页面大小)

分别考虑系统提供给该进程使用的内存的物理块(即页面)数目是3页、4页、5页、6页、7页、8页的情况。

计算并输出下述各种算法在系统给该进程使用的内存的物理块(即页面)数目分别是3~8页时的命中率,按类似表格的排版输出。

(以下三种页面置换算法,至少实现其中之一)

1)FIFO先进先出   2)LRU最近最久未使用  3)OPT最佳置换算法

实验效果参考:

#include<unistd.h>

#include <stdlib.h>

#include<stdio.h>

void randarray(int a[],int k)

{   int i;

    float s;

    srand(getpid());

    s=(float)319.0*(rand()%32767)/32767.0+1.0;

    for(i=0;i<k;i+=4)

    {

        a[i]=(int)s+512;

        a[i+1]=a[i]+513;

        a[i+2]=(int)((float)a[i]*(rand()%32767)/32767.0)+512;

        a[i+3]=a[i+2]+1;

        s=(float)(rand()%32767)*(318.0-a[i+2])/32767.0+a[i+2]+2.0+512;

    }

}

int loop(int b[],int j,int a1)

{

        for(int i=0;i<j;i++)

        {

        if(b[i]==a1)

        return 0;

        }

return 1;

}

void FIFo(int a[]){

printf("FIF0\t");

    int b[9],a1,b1=0,t=0;

for(int j=3;j<=8;j++)

{

    b1=0;t=0;

    for(int i=0;i<320;i++)

    {

//      printf("%d",i);

        a1=a[i]/512;

        if(a[i]%512>0)

        a1=a1+1;

        if(i<j)

        {

        b[i]=a1;

        }

        if(i>=j)

        if( loop(b,j,a1))

            {

            b1=b1%j;

            b[b1]=a1;

            t++;

            b1++;

            }

    }

    printf("%f\t",(float)(320-t)/320);

}

}

void LRU(int a[])

{

    printf("LRU\t");

    int b[9],a1,b1=0,t=0;

for(int j=3;j<=8;j++)

{

    b1=0;t=0;

    for(int i=0;i<320;i++)

    {

//      printf("%d",i);

        a1=a[i]/512;

        if(a[i]%512>0)

        a1=a1+1;

        if(i<j)

        {

        b[i]=a1;

        }

        if(i>=j)

        if( loop(b,j,a1))

            {

                for(int k=0;k<j;k++)

                {

                   if(b[k]==a[i-j])

                   {

                   b[k]=a[i];

                   break;

                }

                }

                t++;

            }

    }

    printf("%f\t",(float)(320-t)/320);

}

}

int main()

{

int a[350],k=320;

randarray(a,k);

printf("table\t3\t4\t5\t6\t7\t8\n");

FIFo(a);

printf("\n");

LRU(a);

printf("\n");

return 0;

}

1.

1.

首先是用数组存储了所有随机数地址,FIFO算法主要靠在没有找到元素时不断淘汰最早进入数组的元素来实现(类似队列的方式);要注意遍历寻找时不要越界和存储出现缺页的情况记录下来。

2.

LRU算法主要注意在分块的时间线末端,记录下来该页的页号。 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/713725.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2024年大数据领域的主流分布式计算框架有哪些

Apache Spark 适用场景 以批处理闻名&#xff0c;有专门用于机器学习的相关类库进行复杂的计算&#xff0c;有SparkSQL可以进行简单的交互式查询&#xff0c;也可以使用DataSet&#xff0c;RDD&#xff0c;DataFrame进行复杂的ETL操作。 关键词 处理数据量大批计算微批计算…

[Qt的学习日常]--常用控件1

前言 作者&#xff1a;小蜗牛向前冲 名言&#xff1a;我可以接受失败&#xff0c;但我不能接受放弃 如果觉的博主的文章还不错的话&#xff0c;还请点赞&#xff0c;收藏&#xff0c;关注&#x1f440;支持博主。如果发现有问题的地方欢迎❀大家在评论区指正 目录 一、什么是控…

【2024亲测无坑】Oracle--19C在Centos7上的静默安装(rpm版)

一、Oracle 19c Linux安装&#xff08;Centos 7&#xff09; 1.查看磁盘可用空间及配置ip地址 [rootlocalhost /]# df -h 文件系统 容量 已用 可用 已用% 挂载点 devtmpfs 1.4G 0 1.4G 0% /dev tmpfs 1.4G …

进程信号(下)

上文&#xff1a;进程信号&#xff08;上&#xff09;-CSDN博客 在上篇中&#xff0c;我们讲了关于信号的保存&#xff0c;信号集的操作&#xff0c;那么这篇我们就来看看信号的原理。 目录 1. 键盘产生信号的原理 2. 信号是如何被处理的&#xff1f; 2.1 信号处理的原理 …

深度神经网络——深度学习中的 RNN 和 LSTM 是什么?

引言 自然语言处理和人工智能聊天机器人领域许多最令人印象深刻的进步都是由 递归神经网络&#xff08;RNN&#xff09; 和长短期记忆&#xff08;LSTM&#xff09;网络。 RNN 和 LSTM 是特殊的神经网络架构&#xff0c;能够处理顺序数据&#xff0c;即按时间顺序排列的数据。…

实用软件下载:会声会影2023最新安装包及详细安装教程

会声会影2023的智能工具&#xff0c;使用AI面部识别对效果最好的照片和视频片段进行分析&#xff0c;提取&#xff0c;并编译到可以项目中&#xff0c;将我们的精彩时刻、美好回忆和媒体内容转换为影片。 全新的AR贴纸让视频更具感染力和趣味性&#xff0c;AR贴纸功能可以识别并…

python 实现各种数据分析方法

1、相关性分析 1.1、https://zhuanlan.zhihu.com/p/669355778https://zhuanlan.zhihu.com/p/669355778

Jacob环境探索(兼容性、管理员、DLL位置、VS环境,COM权限)

概述&#xff1a; 最近在生产开发实践出现了很多问题&#xff0c;经过了一系列排查&#xff0c;特做如下总结 探索成果&#xff1a; 1. jacob.dll的建议位置 首先jacob的官网&#xff0c;以及官方GitHub&#xff0c;你可以从这里找到DLL文件&#xff0c;以及相关资料然后DLL文…

WordPress——Argon主题美化

文章目录 Argon主题美化插件类类别标签页面更新管理器文章头图URL查询监视器WordPress提供Markdown语法评论区头像设置发信设置隐藏登陆备份设置缓存插件 主题文件编辑器页脚显示在线人数备案信息(包含备案信息网站运行时间)banner下方小箭头滚动效果站点功能概览下方Links功能…

GitHub Copilot 登录账号激活,已经在IntellJ IDEA使用

GitHub Copilot 想必大家都是熟悉的&#xff0c;一款AI代码辅助神器&#xff0c;相信对编程界的诸位并不陌生。 今日特此分享一项便捷的工具&#xff0c;助您轻松激活GitHub Copilot&#xff0c;尽享智能编码之便利&#xff01; GitHub Copilot 是由 GitHub 和 OpenAI 共同开…

38、基于卷积神经网络(CNN)的车牌自动识别系统(matlab)

1、原理及流程 1&#xff09;原理 CNN&#xff08;卷积神经网络&#xff09;是一种深度学习模型&#xff0c;可以用于图像识别和分类任务。车牌自动识别系统的原理基本上就是使用CNN模型对车牌图像进行处理和识别。 首先&#xff1a;系统需要收集大量的含有车牌的图像数据作…

windows系统,家庭自用NAS。本地局域网 Docker安装nextcloud

windows系统&#xff0c;家庭自用NAS。本地局域网 Docker安装nextcloud 1、docker安装 太简单了&#xff0c;直接去搜一搜。 docker-compose 相关命令 docker-compose down docker compose up -d2、还是使用老的 在你需要挂载的目录下&#xff0c;新建一个文件&#xff0c;…

航顺MCU概览

前言: 截止2023年底,全国有3451家芯片设计公司,已经IPO的就有168家,尚未IPO的3283家中超过一半的年营收在1000万以下,迅猛发展的几年的确有些国产芯片开始站上赛道,这也是国际大背景下的一种必然选择,毕竟突然间出现的大市场需要国产顶上,但资本市场是周期性的,国产替…

港科夜闻 | 香港科大与香港科大(广州)合推红鸟跨校园学习计划,共享教学资源,促进港穗学生交流学习...

关注并星标 每周阅读港科夜闻 建立新视野 开启新思维 1、香港科大与香港科大(广州)合推“红鸟跨校园学习计划”&#xff0c;共享教学资源&#xff0c;促进港穗学生交流学习。香港科大与香港科大(广州)6月14日共同宣布推出“红鸟跨校园学习计划”&#xff0c;以进一步加强两校学…

transformer和Non-local

两者本质上是一个东西&#xff0c;都是用来求自注意力的&#xff0c;但具体而言还是有一些差别&#xff1b; 1&#xff1a;首先说Non-local&#xff0c;它是像素级别的self-attention,算的是图片中各个像素点对指定像素点的影响&#xff1b; 2&#xff1a;transformer我们拿s…

算法人生(22):从“生成对抗网络”看“逆商提升”

​ 在图像生成与编辑、音频合成、视频生成领域里&#xff0c;有一个非常重要的深度学习方法——生成对抗网络&#xff08;简称GANs&#xff09;&#xff0c;它是由两个神经网络组成的模型&#xff0c;分别为生成器&#xff08;Generator&#xff09;和判别器&#xff08;Discr…

移动硬盘数据恢复方法哪个好?六个硬盘恢复,新手也能用!

移动硬盘数据恢复方法哪个好&#xff1f;移动硬盘&#xff0c;作为我们存储重要数据的常用设备&#xff0c;一旦里面的视频、文档、音频等资料突然消失&#xff0c;确实会令人烦恼和担忧。然而&#xff0c;因为数据丢失的原因可能多种多样&#xff0c;因此恢复方法也会有所不同…

【嵌入式DIY实例】-Nokia 5110显示DS3231 RTC数据

Nokia 5110显示DS3231 RTC数据 文章目录 Nokia 5110显示DS3231 RTC数据1、硬件准备与接线2、代码实现本文将介绍如何使用 ESP8266 NodeMCU 板和 DS3231 RTC 模块制作一个简单的数字实时时钟,其中可以使用连接到 NodeMCU 的两个按钮设置时间和日期,并将它们打印在诺基亚 5110 …

Ubuntu server 24 (Linux) 新增磁盘 lvm 动态扩容磁盘空间

1 新增一块硬盘 #查看 sudo fdisk -l #重新分区&#xff0c;转换成lvm类型 sudo fdisk /dev/sdb 2 查看磁盘 df -h3 lvm 配置 #查看lvm逻辑卷 sudo lvdisplay #创建物理卷 sudo pvcreate /dev/sdb1 #扩展卷组 sudo vgextend ubuntu-vg /dev/sdb1 #扩展逻辑卷 sudo lvexte…

【Linux】pycharmgit相关操作

目录 1. git安装配置2. 相关内容3. pycharm连接远程仓库3.1 配置3.2 clone远程仓库3.3 本地仓库上传远程 4. 分支管理4.1 更新代码4.2 新建分支4.3 分支合并4.4 代码比对 5. 版本管理6. 命令行操作6.1 配置git6.2 基础操作6.3 分支操作 1. git安装配置 下载链接&#xff1a;官…