zoukankan      html  css  js  c++  java
  • 001 LRU-缓存淘汰算法

    1.介绍

      LRU是LeastRecentlyUsed近期最少使用算法。内存管理的一种页面置换算法,对于在内存中但又不用的数据块(内存块)叫做LRU,Oracle会根据哪些数据属于LRU而将其移出内存而腾出空间来加载另外的数据。

      LRU(Least recently used,最近最少使用)算法根据数据的历史访问记录来进行淘汰数据,其核心思想是“如果数据最近被访问过,那么将来被访问的几率也更高”。

    2.实现原理图

      使用链表保存缓存数据实现。

      

      1. 新数据插入到链表头部;

      2. 每当缓存命中(即缓存数据被访问),则将数据移到链表头部;

      3. 当链表满的时候,将链表尾部的数据丢弃。

    3.命中率

      当存在热点数据时,LRU的效率很好,但偶发性的、周期性的批量操作会导致LRU命中率急剧下降,缓存污染情况比较严重。

    4.举例

      假设 序列为 4 3 4 2 3 1 4 2,物理块有3个

      则:

      首轮 4调入内存 4

      次轮 3调入内存 3 4

      之后 4调入内存 4 3

      之后 2调入内存 2 4 3

      之后 3调入内存 3 2 4

      之后 1调入内存 1 3 2(因为最少使用的是4,所以丢弃4)

      之后 4调入内存 4 1 3(原理同上)

      最后 2调入内存 2 4 1

      

  • 相关阅读:
    7,C++ public, protected, private 继承的区别
    6,又一道经典的微软题
    5,一道经典的微软程序题
    33. Search in Rotated Sorted Array
    198,House Robber
    4,二维数组中指针的问题
    剑指offer——stack与queue的互相实现
    3,C语言文件读写
    2,虚函数
    剑指offer——已知二叉树的先序和中序排列,重构二叉树
  • 原文地址:https://www.cnblogs.com/juncaoit/p/6305601.html
Copyright © 2011-2022 走看看