美文网首页
存淘汰算法--LRU算法

存淘汰算法--LRU算法

作者: 5a9c6f44e578 | 来源:发表于2017-10-13 13:50 被阅读11次

1. LRU1.1. 原理

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

1.2. 实现

最常见的实现是使用一个链表保存缓存数据,详细算法实现如下:


  1. 新数据插入到链表头部;
  2. 每当缓存命中(即缓存数据被访问),则将数据移到链表头部;
  3. 当链表满的时候,将链表尾部的数据丢弃。

1.3. 分析

【命中率】
当存在热点数据时,LRU的效率很好,但偶发性的、周期性的批量操作会导致LRU命中率急剧下降,缓存污染情况比较严重。
【复杂度】
实现简单。
【代价】
命中时需要遍历链表,找到命中的数据块索引,然后需要将数据移到头部。

引用:
http://flychao88.iteye.com/blog/1977653

相关文章

网友评论

      本文标题:存淘汰算法--LRU算法

      本文链接:https://www.haomeiwen.com/subject/ppszyxtx.html