本文以序列长度20的{ 7,0,1,2,0,3,0,4,2,3,0,3,2,1,2,0,1,7,0,1};以及页面4;为例;

  1. #include <stdio.h>
  2.  
  3. #define InitPysiBlocks 4
  4. #define MaxPages 20
  5. int PysicalBlocks[InitPysiBlocks] = { -,-,-,- };
  6. int PageSequence[MaxPages] = { ,,,,,,,,,,,,,,,,,,,};
  7.  
  8. void LRU(int py[],int pg[])
  9. {
  10. int i,j,k,m,flag[MaxPages],temp[MaxPages][InitPysiBlocks];
  11. int max = ;
  12. char f[MaxPages];
  13. for(i = ; i < InitPysiBlocks; i++)
  14. {
  15. py[i] = pg[i];
  16. flag[i] = i;
  17. f[i] = '*';
  18. for(j = ; j < InitPysiBlocks; j++)
  19. temp[i][j] = py[j];
  20. }
  21. for(i = InitPysiBlocks; i < MaxPages; i++)
  22. {
  23. for(j = ,k = ; j < InitPysiBlocks; j++)
  24. {
  25. if(py[j] != pg[i])
  26. k++;
  27. else
  28. flag[j] = i;
  29. }
  30. if(k == InitPysiBlocks)
  31. {
  32. f[i] = '*';
  33. max = flag[] < flag[]?:;
  34. for(m = ; m < InitPysiBlocks; m++)
  35. if(flag[m] < flag[max])
  36. max = m;
  37. py[max] = pg[i];
  38. flag[max] = i;
  39. for(j = ; j < InitPysiBlocks; j++)
  40. temp[i][j] = py[j];
  41. }
  42. else
  43. {
  44. f[i] = ' ';
  45. for(j = ; j < InitPysiBlocks; j++)
  46. temp[i][j] = py[j];
  47. }
  48. }
  49. printf("输出结果为下表(-1代表为空,*代表有缺页):\n");
  50. for(i = ; i < InitPysiBlocks; i++)
  51. {
  52. for(j = ; j < MaxPages; j++)
  53. printf("%3d",temp[j][i]);
  54. printf("\n");
  55. }
  56. for(i = ; i < MaxPages; i++)
  57. printf("%3c",f[i]);
  58. printf("\n");
  59. }
  60.  
  61. void main()
  62. {
  63. LRU(PysicalBlocks,PageSequence);
  64. }

测试:

LRU页面置换算法的更多相关文章

  1. 操作系统-2-存储管理之LRU页面置换算法(LeetCode146)

    LRU缓存机制 题目:运用你所掌握的数据结构,设计和实现一个  LRU (最近最少使用) 缓存机制. 它应该支持以下操作: 获取数据 get 和 写入数据 put . 获取数据 get(key) - ...

  2. 操作系统页面置换算法(opt,lru,fifo,clock)实现

    选择调出页面的算法就称为页面置换算法.好的页面置换算法应有较低的页面更换频率,也就是说,应将以后不会再访问或者以后较长时间内不会再访问的页面先调出. 常见的置换算法有以下四种(以下来自操作系统课本). ...

  3. [Operate System & Algorithm] 页面置换算法

    页面置换算法是什么?我们看一下百度百科对页面置换算法给出的定义:在地址映射过程中,若在页面中发现所要访问的页面不在内存中,则产生缺页中断.当发生缺页中断时,如果操作系统内存中没有空闲页面,则操作系统必 ...

  4. 操作系统 页面置换算法LRU和FIFO

    LRU(Least Recently Used)最少使用页面置换算法,顾名思义,就是替换掉最少使用的页面. FIFO(first in first out,先进先出)页面置换算法,这是的最早出现的置换 ...

  5. (待续)C#语言中的动态数组(ArrayList)模拟常用页面置换算法(FIFO、LRU、Optimal)

    目录 00 简介 01 算法概述 02 公用方法与变量解释 03 先进先出置换算法(FIFO) 04 最近最久未使用(LRU)算法 05 最佳置换算法(OPT) 00 简介 页面置换算法主要是记录内存 ...

  6. 页面置换算法 - FIFO、LFU、LRU

    缓存算法(页面置换算法)-FIFO. LFU. LRU 在前一篇文章中通过leetcode的一道题目了解了LRU算法的具体设计思路,下面继续来探讨一下另外两种常见的Cache算法:FIFO. LFU ...

  7. 页面置换算法(最佳置换算法、FIFO置换算法、LRU置换算法、LFU置换算法)

    页面置换产生的原因是:分页请求式存储管理(它是实现虚拟存储管理的方法之一,其中一个特性是多次性-->多次将页面换入或换出内存) 效果最好的页面置换算法:最佳置换算法 比较常用的页面置换算法有:F ...

  8. 操作系统笔记(六)页面置换算法 FIFO法 LRU最近最久未使用法 CLOCK法 二次机会法

    前篇在此: 操作系统笔记(五) 虚拟内存,覆盖和交换技术 操作系统 笔记(三)计算机体系结构,地址空间.连续内存分配(四)非连续内存分配:分段,分页 内容不多,就不做index了. 功能:当缺页中断发 ...

  9. 页面置换算法-LRU(Least Recently Used)c++实现

    最近最久未使用(LRU)置换算法 #include <iostream> #include <cstdio> #include <cstring> #include ...

随机推荐

  1. Linux下查看某进程相关进程

    1- ps -T <pid> ###pid表示进程号 或者ps -T -p <pid> 2-   top -H -p <pid>  ###pid表示进程号 3-  ...

  2. flex布局

    一,啥是flex? 1.Flex是Flexible Box的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性.任何一个容器都可以指定为Flex布局. .box{ displa ...

  3. MyBatis基于注解的动态SQL——概览

  4. Android studio 出现 Unsupported major.minor version 52.0

    参考资料:http://blog.csdn.net/fakine/article/details/51241202 最近更新了Android studio 之后,出现了Error:java.lang. ...

  5. 【转】Deadlock的一些总结(死锁分析及处理)

    1.1.1 摘要 在系统设计过程中,系统的稳定性.响应速度和读写速度至关重要,就像12306.cn那样,当然我们可以通过提高系统并发能力来提高系统性能总体性能,但在并发作用下也会出现一些问题,例如死锁 ...

  6. 从零开始攻略PHP(7)——面向对象(上)

    1.理解面向对象的概念 面向对象软件的一个重要优点是支持和鼓励封装的能力.封装也叫数据隐藏. 在面向对象的软件中,对象是一个被保存数据和操作这些数据的操作方法的唯一.可标识的集合. 对象可以按类进行分 ...

  7. linux上监控tomcat down掉后自动重启tomcat

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "Helvetica Neue"; color: #454545 } p. ...

  8. NOI 1.5 41:数字统计

    描述 请统计某个给定范围[L, R]的所有整数中,数字2出现的次数. 比如给定范围[2, 22],数字2在数2中出现了1次,在数12中出现1次,在数20中出现1次,在数21中出现1次,在数22中出现2 ...

  9. Android 蓝牙API详解

    随着近两年可穿戴式产品逐渐进入人们的生活,蓝牙开发也成为了Android开发的一个重要模块,下面我们就来说一说蓝牙的这些API. 1.蓝牙开发有两个主要的API: BuletoothAdapter:本 ...

  10. (一)Nand FLASH 原理讲解

    NAND FLASH  优势 : 可以用当硬盘   这里好像型号是 K9F2G08 基本结构: 不是很难自己看看,暂时不要看