实验二 存储器管理

实验二   存储器管理

实验目的

理解各类置换算法的原理和虚拟存储器管理的方法。

实验内容:

编程实现LRU算法或CLOCK/改进算法等置换算法(二选一),模拟实现虚拟存储器的地址变换过程。

实验步骤:

1.改进型CLOCK算法

(1)改进型ClOCK算法描述:

在将一个页面换出时,如果该页已被修改过,便须将该页重新写回到磁盘上;但如果该页未被修改过,则不必将它拷回磁盘。在改进型CLOCK算法中,除须考虑页面的使用情况外,还须在增加一个因素,即置换代价,这样页面换出时,既要是未使用过的页面,又要是未被修改过的页面。把同时满足这两个条件的页面作为首选淘汰的页面。由访问位A和修改位M可以组合成下面四种类型的页面:

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

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

3类(A=1,M=0):表示该页最近已被访问,但未被修改,该页有可能在被访问。

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

(2)改进型CLOCK页面置换算法的数据结构

1)内存块类和页面类

类名

属性

作用

Block

页面page

修改位modify

访问位access

用于表示一个内存块单元

Page

页号page

修改位modify

用于表示一个页面

注:Page的modify是预设置好的,也就是说页面访问串是预先生成的,生成的内容包括页面号和访问位,也就模拟了系统运行时要访问的页面号和要修改的页面。

(3)简单ClOCK算法流程图

 图1 简单Clock的页面置换算法

(4)改进型Clock页面置换算法流程图。

 

图2 改进型Clock页面置换算法流程图

 

2.改进型Clock算法的代码实现

(1)代码目录结构如图3所示。从上到下依次为内存块类,改进型页面置换算法及其测试代码,页面类。

图3 改进型Clock页面置换算法代码目录结构

 (2)Page页面类的代码如下。

public class Page{
	int page = -1;
	int modify = 0;
public Page(int page,int modify){
    this.page = page;
    this.modify = modify;
}


}

(3)Block页面块的代码如下。

public class Block {
	int page = -1;
	int access = 0;
	int modify = 0;
}

(4)Clock页面置换算法及其测试类的代码如下。测试数据通过三种方式实现,一种是随机生成,一种是自己输入+随机,最后一种是自己输入。

import java.util.Random;
import java.util.Scanner;
//改进型的页面置换算法
public class ClockTest {
		
		public static void main(String[] args) {
		    int size = 3;
		    int pagesize = 10;
		    Scanner in = new Scanner(System.in);
		    System.out.println("**************************************************************");
		    System.out.println("*************************改进型clock算法***************************");
		    System.out.println("*************注:预先生成页面访问序列再去调用页面置换算法,同时设置修改位***************");
		    System.out.println("**************************************");
		    System.out.println("请输入内存块的大小:");
		    size = in.nextInt();
		    Block[] arr = new Block[size];
		    for(int i = 0;i < size;i++){
		        arr[i] = new Block();
		    }
		    System.out.println("请输入访问页面的容量");
		    pagesize = in.nextInt();
		    Page[] pages = new Page[pagesize];

		    System.out.println("请选择操作(输入数字1或2或3):");
		    System.out.println("1、随机生成页面访问序列和修改位");
		    System.out.println("2、动态指定访问序列,随机生成修改位");
		    System.out.println("3、动态指定访问序列和修改位");
		    int action = in.nextInt();

		    Random random = new Random();
		    if(action == 1){
		        for(int i = 0;i < pagesize;i++){
		            pages[i] = new Page(random.nextInt(8),Math.abs(random.nextInt(10)%2));
		        }
		    }else if(action == 2){

		        for(int i = 0;i < pagesize;i++){
		            System.out.println("请输入第" + i + "个页号");
		            pages[i] = new Page(in.nextInt(),Math.abs(random.nextInt(10)%2));
		        }
		    }else if(action ==3){
		        for(int i = 0;i < pagesize;i++){
		            System.out.println("请输入第" + i + "个页号和是否被会被修改(1为修改0为未修改)");
		            pages[i] = new Page(in.nextInt(),in.nextInt());//模拟页号为1的页面不会被修改
		        }
		    }
		    System.out.println("===要访问的页面串如下===");
		    System.out.println("页面号\t是否被修改");
		    for (Page page : pages) {
		        System.out.println(page.page+"\t"+page.modify);
		    }
		    clock(arr,pages);
		}
	
		public static void clock(Block[] block,Page[] page){
		    boolean flag = false; 
		    int count = 0;   //缺页数
		    for(int i = 0;i < page.length;i++){
		    	 System.out.println("页面置换前的内存块的使用情况");
		    	 System.out.println("页面号\t"+"访问位\t"+"修改位\t");
		        for (int m = 0;m < block.length;m++) {
		        	
		            System.out.println( block[m].page +"\t" + block[m].access + "\t"+block[m].modify);
		        }
		        System.out.println("将要访问的页面---"+page[i].page);
		        if(contain(block,page[i])){
		            System.out.println("命中!");
		            System.out.println("页面号\t"+"访问位\t"+"修改位\t");
			        for (int m = 0;m < block.length;m++) {
			        	
			            System.out.println( block[m].page +"\t" + block[m].access + "\t"+block[m].modify);
			        }
		            System.out.println("*****************************************");
		            continue;
		        }else{
		            System.out.println("缺页...");
		            count++;
		            flag = false;
		        }

		    
		        while(!flag){
		        	
		            for(int j = 0;j < block.length;j++){
		                if(block[j].access == 0 && block[j].modify == 0){
		                    block[j].page = page[i].page;
		                    block[j].access = 1;
		                    block[j].modify=page[i].modify;
		                    flag = true;
		                    break;
		                }
		            }
		           
		            if(flag){
		                break;
		            }

		            for(int j = 0;j < block.length;j++){

		                if(block[j].access == 0 && block[j].modify == 1){
		                    block[j].page = page[i].page;
		                    block[j].access = 1;
		                    flag = true;
		                    break;
		                }else{
		                    block[j].access = 0;
		                }
		            }
		        }
		        System.out.println("页面号\t"+"访问位\t"+"修改位\t");
		        for (int m = 0;m < block.length;m++) {
		        	
		            System.out.println( block[m].page +"\t" + block[m].access + "\t"+block[m].modify);
		        }		        System.out.println("*****************************************");
		    }

		    System.out.println("缺页次数:" + count);
		    System.out.println("缺页率:" + (count*1.0)/page.length);
		}

		public static boolean contain(Block[] block,Page page){
		    for(int i = 0;i < block.length;i++){
		        if(block[i].page == page.page){
		            block[i].page = page.page;
		            block[i].access = 1;
		            block[i].modify = page.modify;
		            return true;
		        }
		    }
		    return false;
		}
		}	

(5)改进型Clcok页面置换算法的测试。

1)针对3个内存块,8个页面访问序列的情况的测试效果如图4-图6所示,图4采用的是随机生成的数据,图5页面置换的过程,图6显示的是缺页次数和缺页率。注:-1代表内存块未使用。

 测试:输入内存块3,页面大小8,采用1随机的方式

暂无,详见文字描述

图4 页面数据初始化

 

图5 页面置换过程

图6 缺页次数和缺页率

 2)针对个5内存块,8个页面访问序列的情况的测试效果如图7-图9所示,图7采用的是随机生成的数据,图8页面置换的过程,图9显示的是缺页次数和缺页率。注:-1代表内存块未使用。

测试:输入内存块5,页面大小8,采用1随机的方式

暂无,详见文字描述

图7 页面数据初始化

图8 页面置换过程

图9 缺页次数和缺页率

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

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

相关文章

【Golang项目实战】用Go写一个学生信息管理系统,真的太酷啦| 保姆级详解,附源码——建议收藏

博主简介&#xff1a;努力学习的大一在校计算机专业学生&#xff0c;热爱学习和创作。目前在学习和分享&#xff1a;数据结构、Go&#xff0c;Java等相关知识。博主主页&#xff1a; 是瑶瑶子啦所属专栏: Go语言核心编程近期目标&#xff1a;写好专栏的每一篇文章 学习了Go的基…

图神经网络:在自定义数据集上动手实现图神经网络

文章说明&#xff1a; 1)参考资料&#xff1a;PYG官方文档。超链。 2)博主水平不高&#xff0c;如有错误还望批评指正。 文章目录 自定义数据集动手实现图神经网络自定义数据集训验测集拆分&#xff0c;创建Data的数据结构&#xff0c;观察Data的基本信息&#xff0c;可视化图网…

震惊,为了学会泛型类竟做这种事?!

上一节&#xff0c;我们基本学会了Java泛型类的用法。 传送门&#xff1a;彻底弄懂Java的泛型 - 泛型类 这一节&#xff0c;我们转变一下风格&#xff0c;具体是什么风格呢&#xff0c;你马上就懂了。 宝子们&#xff0c;欢迎大家来到我们的泛型直播间&#xff0c;这一讲呢&a…

Ansible的脚本-playbook 剧本

目录 1.剧本&#xff08;playbook&#xff09; 1.playbook介绍 2. playbooks 的组成 3.案例&#xff1a;编写httpd的playbook 4.定义、引用变量 5.指定远程主机sudo切换用户 6.when条件判断 7.迭代 2.playbook的模块 1.Templates 模块 2.tags 模块 3.Roles 模块 1.…

【Linux从入门到精通】vim的基本使用各种操作详解

文章目录 一、vim编辑器简单介绍 二、vim编辑器的四种模式 2、1 正常/普通/命令模式(Normal mode) 2、2 插入模式(Insert mode) 2、3 末行模式(last line mode) 三、命令模式的相关操作实例 3、1 光标的相关操作 3、2 文本操作 四、插入模式下的相关操作 五、末行模式下的相关操…

Java—JDK8新特性—函数式接口

目录 函数式接口 3.1 什么是函数式接口 3.2 functionalinterface注解 源码分析 3.3 Lambda表达式和函数式接口关系 3.4 使用函数式接口 函数式接口 3.1 什么是函数式接口 如果一个接口中只包含一个抽象方法&#xff0c;这个接口称为函数式接口 如果一个接口包含&#xff0…

K8S管理系统项目实战[API开发]-2

后端: gogin 后端代码地址GitHub - yunixiangfeng/k8s-platform: K8s管理系统后端: gogin 5、存储与配置 5.1 ConfigMap 5.2 Secret 5.3 PersistentVolumeClaims 6、工作流 6.1 流程设计 6.2 数据库操作&#xff08;GORM&#xff09; &#xff08;1&#xff09;初始化…

交换机-Exchanges

交换机 Exchanges 概念 RabbitMQ 消息传递模型的核心思想是: 生产者生产的消息从不会直接发送到队列。实际上&#xff0c;通常生产者甚至都不知道这些消息传递传递到了哪些队列中。相反&#xff0c;生产者只能将消息发送到交换机(exchange)&#xff0c;交换机工作的内容非常简…

正则表达式-基本元字符和语法规则

© Ptw-cwl 文章目录 字符匹配元字符.元字符[]元字符[^]元字符*元字符元字符?元字符{}元字符|元字符()元字符^元字符$元字符\元字符\d元字符\w元字符\s元字符\b元字符\B元字符*?、?、??、{n,m}?元字符(?)、(?!)元字符(?:)元字符\1、\2等元字符^、$元字符&#x…

JavaSE基础(二)—— 类型转换、运算符、键盘录入

目录 一、类型转换 1. 自动类型转换 1.1 自动类型转换的底层原理&#xff1a; ​1.2 自动类型转换的其他形式​编辑 2. 表达式的自动类型转换 3. 强制类型转换 3.1 强制类型转换底层原理​编辑 3.2 注意事项 二、运算符 1. 算数运算符 1.1 案例&#xff1a;数值拆分…

PCA主成成分分析例题详解

主成分分析是一种降维算法&#xff0c;它能将多个指标转换为少数几个主成分&#xff0c;这些主成分是原始变量的线性组合&#xff0c;且彼此之间互不相关&#xff0c;其能反映出原始数据的大部分信息 需要了解具体细节可看此视频&#x1f449;&#xff1a;什么是主成成分分析PC…

Linux安装MongoDB数据库,并内网穿透远程连接

文章目录 前言1. 配置Mongodb源2. 安装MongoDB3. 局域网连接测试4. 安装cpolar内网穿透5. 配置公网访问地址6. 公网远程连接7. 固定连接公网地址8. 使用固定地址连接 转载自Cpolar Lisa文章&#xff1a;Linux服务器安装部署MongoDB数据库 - 无公网IP远程连接「内网穿透」 前言 …

SpringBoot访问静态资源

SpringBoot项目中没有WebApp目录&#xff0c;只有src目录。在src/main/resources下面有static和templates两个文件夹。SpringBoot默认在static目录中存放静态资源&#xff0c;而templates中放动态页面。 static目录 SpringBoot通过/resources/static目录访问静态资源&#xff…

完成A轮融资,倍思如何发力场景化为品牌创造广阔未来?

凛冬过后的消费电子正在重新凝聚资本的目光。 近日&#xff0c;深圳市倍思科技有限公司宣布完成由深创投、中金资本联合领投&#xff0c;越秀产业基金、高榕资本跟投&#xff0c;金额数亿元人民币的A轮融资。 分析人士指出&#xff0c;消费电子的行业景气度在逐渐恢复&#x…

中国社科院与美国杜兰大学金融管理硕士项目——迎接立夏,切莫忘记自我成长

五月的风吹走了春季&#xff0c;今天我们迎来立夏。作为夏季的第一个节气&#xff0c;立夏常被人们当做万物蓄满能量&#xff0c;即将加速生长的标志。而在职的我们&#xff0c;也应该跟这世间万物一样&#xff0c;在季节交替之时沉淀自己、努力向上成长。在社科院与杜兰大学金…

“人工智能教父”从谷歌离职 称后悔发展AI,为世人敲响警钟?

在加入谷歌的第十年、深度学习迎来爆发式发展的当下&#xff0c;被誉为“人工智能教父”的Geoffrey Hinton已从谷歌离职&#xff0c;只是为了告诫人们AI已经变得很危险。 公开资料显示&#xff0c;Geoffrey Hinton在2013年加入谷歌&#xff0c;曾任副总裁&#xff0c;研究机器学…

成为数据分析师,需要具备哪些技能?

随着互联网的发展&#xff0c;数据分析师的特点越来越明显&#xff0c;对数据分析师综合素质的要求也较高。 1、较强的数据挖掘、信息整理、和逻辑分析能力 数据分析&#xff0c;也是数据分析师的一个方向。 制作日常性的经营报表&#xff0c;对公司或者行业KPI指标进行拆解…

Mysql索引(3):索引分类

1 索引分类 在MySQL数据库&#xff0c;将索引的具体类型主要分为以下几类&#xff1a;主键索引、唯一索引、常规索引、全文索引。 分类含义特点关键字主键索引针对于表中主键创建的索引 默认自动创建, 只能有一个 PRIMARY 唯一索引 避免同一个表中某数据列中的值重复可以有多…

【Android入门到项目实战-- 8.4】—— 如何解析JSON格式数据

目录 一、准备工作 二、使用JSONObject 三、使用GSON 比起XML&#xff0c;JSON的主要优势在于它的体积更小&#xff0c;在网络上传输的时候可以更省流量&#xff0c;但缺点是语义性较差&#xff0c;看起来不直观。 一、准备工作 还是使用前面文章的方法&#xff0c;在服务器…

每日学术速递4.29

CV - 计算机视觉 | ML - 机器学习 | RL - 强化学习 | NLP 自然语言处理 Subjects: cs.LG 1.A Cookbook of Self-Supervised Learning 标题&#xff1a;自监督学习食谱 作者&#xff1a;Randall Balestriero, Mark Ibrahim, Vlad Sobal, Ari Morcos, Shashank Shekhar, Tom…