【操作系统】页面置换算法(最佳置换算法)(C语言实现)
【操作系统】页面置换算法(最佳置换算法)(C语言实现)
(编码水平较菜,写博客也只是为了个人知识的总结和督促自己学习,如果有错误,希望可以指出)
1.页面置换算法:
在地址映射过程中,若在页面中发现所要访问的页面不在内存中,则产生缺页中断。当发生缺页中断时,如果操作系统内存中没有空闲页面,则操作系统必须在内存选择一个页面将其移出内存,以便为即将调入的页面让出空间。而用来选择淘汰哪一页的规则叫做页面置换算法。
一个好的页面置换算法,应具有较低的页面更换频率。从理论上讲,应该保留最近重复访问的页面,将以后都不再访问或者很长时间内不再访问的页面调出。----百度百科
2.具体的页面置换算法:
2.1 最佳置换算法:一个进程在内存的若干个页面中,哪一个页面是未来最长时间内不再被访问的,那么如果发生缺页中断时,就将该页面换出,以便存放后面调入内存中的页面。
1.这是计算机操作系统(第四版)中的一个例子。系统首先为进程分配了三个物理块。上面一排数字是作业号。在转满三个物理块后,要访问2号作业,2号作业不在内存,所以会发生缺页中断,然后系统需要将2号作业调入内存,但是此时物理块已经装满。
2.依据最佳置换算法,会将7号页换出(0号页在2号页后第1个就会被访问,1号页在2号页后第10个会被访问,7号页在2号页后第14个会被访问,7号页在已经装入内存的作业中是未来最长时间不会被访问的,所以换出7号页)。
3.后面依次类推。
2.2 先进先出算法:如果发生缺页中断,需要换出一个页面的时候,总是选择最早进入内存的页面,即选择在内存中驻留时间最久的页面进行换出。
有点不清楚。。。。。就是每次发生缺页就将最早进入内存的页面换出,然后将刚调入的页面换入该物理块。
2.3 最近最久未使用(LRU)置换算法:LRU算法是缺页中断发生时选择最久未使用的页面进行换出。
这个算法其实也很好判断。分享一个小技巧。内存分配了k个物理块,发生缺页中断将要往内存调入某个页面的时候,在该页面往前面数K个物理块最前面的那个就会是要换出的,因为该页面最长时间未被使用过。(可能前面会有重复的页面,有几个重复的页面就再往前面多数几个)
例如:装入7,0,1,之后访问2号页面的时候会发生缺页中断。此时物理块有三个,2号页面前面有三个页面,最前面的是7号页面所以将7号页面换出。
2.4Clock置换算法(没有动图,不太形象,就不举例子了,如果不太清楚,可以私信我。)
2.4.1简单的Clock置换算法:将所有页面通过链接指针连接成一个循环队列。然后需要为每一个页面设置一个访问位。当某页被访问的时候,将访问位置为1。选择页面换出的时候,需要检查页面的访问位。如果是0,就将页面换出,如果是1,那么就将访问位置为0。
简单的Clock算法最多访问两轮:
最坏情况就是所有的页面访问位都是1,访问1轮之后,全部访问位都会被置为0,那么肯定会找到一个页面换出。
2.42改进型Clock算法:将所有页面通过链接指针连接成一个循环队列。然后需要为每一个页面设置一个访问位和一个修改位。访问位为0表示未访问过,为1表示访问过。修改位为0表示未修改过,为1表示修改过。
此时页面会有四种情况:
1.未被访问,未被修改,最佳淘汰。
2.未被访问,被修改过。
3.被访问过,未被修改。
4.被访问过,被修改过。
换出页面的时候:
1.寻找未被访问,未被修改的页面,不修改访问位。找到则换出,找不到进行第二步。
2.寻找未被访问,但是被修改过的页面。此时,每次扫描页面的时候,将所有访问位置为0。找到就返回,找不到就进行第三步。
3.重复第一次步骤,寻找未被访问,未被修改的页面,不修改访问位。找到则换出,找不到进行第四步。
4.重复第二步。寻找未被访问,但是被修改过的页面。此时一定可以找到。
也就是说,改进型Clock算法,最多扫描四轮队列。因为最坏的情况就是全部页面的访问位和修改位都是1的情况。在经过第二轮扫描之后页面的访问位已经都是0。所以第四轮一定可以找到一个页面换出。
3.最佳置换算法运行截图:
首先是前面三个装入,就省略掉了直接从第四次之后开始打印的。
4.代码
#include<stdio.h>
#include<stdlib.h>
#define MAX 20 // 定义作业序列的最大长度
#define num_alloacte 3 //内存分配给进程的物理块数 , 也就是同一时刻最多有几个页面可以在内存中
int work_list [MAX]; //存储作业序列
int num; //存储要输入的序列的长度
int memory_alloacte [num_alloacte]; // 现在在进程中的页面序列
int current; // 记录已经分配的作业的下标
void input(){ //初始化作业序列 , 以及内存分配给进程的物理块数
printf("请输入作业的个数:");
scanf("%d",&num);
if (num > MAX) {
printf("序列过长");
return;
}
printf("请输入作业序列:\n");
for(int i = 0;i < num; i ++){
scanf("%d",&work_list[i]);
}
for(int i = 0;i < MAX ; i ++){
memory_alloacte[i] = -1;
}
for(int i = 0;i < num_alloacte;i ++){
memory_alloacte[i] = work_list[i];
current = i;
}
}
void print(int* work_list,int* memory_alloacte ){
printf("\t现在进程中的页面序列:");
for(int i = 0; i < num_alloacte; i ++){
printf("%3d\t",*(memory_alloacte+i));
}
printf("\t\t当前剩余的作业序列:");
for(int i = current+1; i < num;i ++){
printf("%3d",*(work_list+i));
}
printf("\n");
}
int judge(){
int temp [num_alloacte]; //赋值一个临时变量 记录此时物理框中的作业号
int count = num_alloacte; //记录临时变量物理框中还剩下的个数
for(int i = 0;i < num_alloacte; i ++){
temp[i] = memory_alloacte[i];
}
int cur = current + 1;
while (cur < num)
{
for (int i = 0; i < num_alloacte; i++)
{
if(work_list[cur] == temp[i]){ //如果剩下的工作序列中 现有内存中的作业还会调用的话, 就将其的值置为 -1
if(count == 1){ //此时内存中剩下的那个作业号肯定是最长时间没有调用过的,后者是以后再也不会调用
return i;
}
temp[i] = -1;
count --;
break;
}
}
cur ++;
}
//此时再来遍历这个 临时的物理块中作业号的 数组 , 如果他的值不是 -1,就说明后面需要调用的作业中再也没有这个作业了,所以 就可以直接返回。
for(int i = 0;i < num_alloacte;i ++){
if(temp[i] != -1){
return i;
}
else
{
continue;
}
}
return 0;
}
void change(){
int index;
int flag = 0;
for (int i = current + 1; i < num; i++)
{
for (int j = 0; j < num_alloacte; j++) //来判断下一个作业是否已经在内存中
{
if(work_list[i] == memory_alloacte[j]){
flag = 1; //是的话让标志位置为1
break;
}
}
if(flag == 0){ //说明不在内存中,会出现页面中断。需要进行换页。
index = judge();
if(memory_alloacte[index] != work_list[i]){
memory_alloacte[index] = work_list[i];
}
current ++;
print(work_list,memory_alloacte);
}
else
{
flag = 0;
current ++;
print(work_list,memory_alloacte);
continue;
}
}
}
int main(){
input();
change();
system("pause");
}
【操作系统】页面置换算法(最佳置换算法)(C语言实现)的更多相关文章
- 页面置换算法(最佳置换算法、FIFO置换算法、LRU置换算法、LFU置换算法)
页面置换产生的原因是:分页请求式存储管理(它是实现虚拟存储管理的方法之一,其中一个特性是多次性-->多次将页面换入或换出内存) 效果最好的页面置换算法:最佳置换算法 比较常用的页面置换算法有:F ...
- 操作系统页面置换算法(opt,lru,fifo,clock)实现
选择调出页面的算法就称为页面置换算法.好的页面置换算法应有较低的页面更换频率,也就是说,应将以后不会再访问或者以后较长时间内不会再访问的页面先调出. 常见的置换算法有以下四种(以下来自操作系统课本). ...
- 操作系统 页面置换算法LRU和FIFO
LRU(Least Recently Used)最少使用页面置换算法,顾名思义,就是替换掉最少使用的页面. FIFO(first in first out,先进先出)页面置换算法,这是的最早出现的置换 ...
- 页面置换算法之Clock算法
1.前言 缓冲池是数据库最终的概念,数据库可以将一部分数据页放在内存中形成缓冲池,当需要一个数据页时,首先检查内存中的缓冲池是否有这个页面,如果有则直接命中返回,没有则从磁盘中读取这一页,然后缓存到内 ...
- [Spark内核] 第34课:Stage划分和Task最佳位置算法源码彻底解密
本課主題 Job Stage 划分算法解密 Task 最佳位置算法實現解密 引言 作业调度的划分算法以及 Task 的最佳位置的算法,因为 Stage 的划分是DAGScheduler 工作的核心,这 ...
- c模拟内存分配算法(首次适应算法,最佳适应算法,最坏适应算法)
#include<bits/stdc++.h> using namespace std; /*定义内存的大小为100*/ #define MEMSIZE 100 /*如果小于此值,将不再分 ...
- Stage划分和Task最佳位置算法源码彻底解密
本课主题 Job Stage 划分算法解密 Task 最佳位置算法实现解密 引言 作业调度的划分算法以及 Task 的最佳计算位置的算法,因为 Stage 的划分是DAGScheduler 工作的核心 ...
- Levenshtein Distance算法(编辑距离算法)
编辑距离 编辑距离(Edit Distance),又称Levenshtein距离,是指两个字串之间,由一个转成另一个所需的最少编辑操作次数.许可的编辑操作包括将一个字符替换成另一个字符,插入一个字符, ...
- [算法]检测空间三角形相交算法(Devillers & Guigue算法)
#pragma once //GYDevillersTriangle.h /* 快速检测空间三角形相交算法的代码实现(Devillers & Guigue算法) 博客原地址:http://bl ...
随机推荐
- 学习笔记:[算法分析]数据结构与算法Python版[基本的数据结构-上]
线性结构Linear Structure ❖线性结构是一种有序数据项的集合,其中 每个数据项都有唯一的前驱和后继 除了第一个没有前驱,最后一个没有后继 新的数据项加入到数据集中时,只会加入到原有 某个 ...
- 应聘阿里,字节跳动,美团必须掌握的Spring IOC与工厂模式
Spring IOC与工厂模式 PS:本文内容较为硬核,需要对java的面向对象.反射.类加载器.泛型.properties.XML等基础知识有较深理解. (一)简单介绍 在讲Spring IOC之前 ...
- Logstash使用mongodb插件报错: ArgumentError: wrong number of arguments (given 2, expected 1)
目录 背景 安装插件过程 背景 今天在使用logstash收集日志存储到mongodb的安装过程遇到了个错误,记录下来,错误就是下面这样: 配置文件很简单,由于是测试环境,命令行传入日志输入由ruby ...
- 洛谷 P1360 [USACO07MAR]Gold Balanced Lineup G (前缀和+思维)
P1360 [USACO07MAR]Gold Balanced Lineup G (前缀和+思维) 前言 题目链接 本题作为一道Stl练习题来说,还是非常不错的,解决的思维比较巧妙 算是一道不错的题 ...
- Unable to locate package python3 错误解决办法
错误 huny@DESKTOP-N1EBKQP:/mnt/c/Users/Administrator$ sudo apt-get install python3 Reading package lis ...
- Java蓝桥杯——排序练习:选美大赛
选美大赛 在选美大奖赛的半决胜赛现场,有一批选手参加比赛,比赛的规则是最后得分越高,名次越低.当半决决赛结束时,要在现场按照选手的出场顺序宣布最后得分和最后名次,获得相同分数的选手具有相同的名次,名次 ...
- 生僻的mysql
1.show table status like 'user' 2.alter table mytableEngine=InnoDB 需要执行很长时间,mysql会按行将数据从原表复制到一张新的表中, ...
- SpringBoot中JPA的学习
SpringBoot中JPA的学习 准备环境和项目配置 写一下学习JPA的过程,主要是结合之前SpringBoot + Vue的项目和网上的博客学习一下. 首先,需要配置一下maven文件,有这么两个 ...
- IEEE浮点数标准
IEEE浮点数标准 阅读笔记:Computer System : A Programmmer's Perspective 基本概念 IEEE浮点数标准采用 \[V=(-1)^s\times M\tim ...
- Java 关于策略模式+简单工厂模式下的思考
导读 最近在做公司一个消息网关的服务,包括:短信.微信.邮件等,所有请求通过一个入口,方便接口的管理(记录日志.接口限流白名单啥的).如何写这个接口呢,还有为了以后扩展,对接过短信.微信.公众号的童鞋 ...