LRU、LFU、FIFO算法总结

原创 2016年08月29日 21:49:36

一、概述

(1)FIFO:First In First Out,先进先出
(2)LRU:Least Recently Used,最近最少使用
(3)LFU:Least Frequently Used,最不经常使用

  
FIFO表示先进先出,类似于对列,在数据的结构上使用对列来实现。
结构图:

1. 新访问的数据插入FIFO队列尾部,数据在FIFO队列中顺序移动;
2. 淘汰FIFO队列头部的数据;

LRU表示很少使用算法,其核心思想是“如果数据最近被访问过,那么将来被访问的几率也更高”。
最常见的实现是使用一个链表保存缓存数据,结构图如下:



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

 LRU和LFU的区别:
LFU算法是根据在一段时间里数据项被使用的次数选择出最少使用的数据项,即根据使用次数的差异来决定。而LRU是根据使用时间的差异来决定的。

LFU表示最不经常使用的算法,其核心思想是“如果数据过去被访问多次,那么将来被访问的频率也更高”。

结构图:


1. 新加入数据插入到队列尾部(因为引用计数为1);
2. 队列中的数据被访问后,引用计数增加,队列重新排序;
3. 当需要淘汰数据时,将已经排序的列表最后的数据块删除。


参考:http://blog.csdn.net/quitepig/article/details/8045187
http://flychao88.iteye.com/blog/1977653  
http://www.cnblogs.com/dolphin0520/p/3749259.html  
版权声明:本文为博主原创文章,未经博主允许不得转载。学习交流QQ群: 173124648

相关文章推荐

FIFO、LRU、OPT页面调度算法及例子

网上很多介绍3种页面置换算法的例子和过程是不正确的, 本文根据《操作系统概念》第七版对三种算法做介绍,并给出正确的例子以验证算法。 一、FIFO先进先出页面置换算法,创建一个FIFO队列来管...

FIFO、LRU、LFU的含义和原理

题目:请简要介绍FIFO、LRU、LFU的含义和原理 含义: FIFO:First In First Out,先进先出 LRU:Least Recently Used...

几种缺页中断算法(FIFO,LRU与LFU)的实现过程

几种缺页中断算法(FIFO,LRU与LFU)的实现过程 2015-09-05 20:34:02 分类: LINUX   最近在做笔试题,其中虚拟存储管理中几种缺页中断算...

FIFO、LRU、OPT这三种置换算法的缺页次数

 虑下述页面走向:           1,2,3,4,2,1,5,6,2,1,2,3,7,6,3,2,1,2,3,6      当内存块数量分别为3时,试问...

LRU和LFU的区别

LRU和LFU是不同的! LRU是最近最少使用页面置换算法(Least Recently Used),也就是首先淘汰最长时间未被使用的页面! LFU是最近最不常用页面置换算法(Least Freq...

[互联网面试笔试汇总C/C++-21] FIFO 、LRU、LFU的含义、原理和实现-完美世界

题目:请简要介绍FIFO、LRU、LFU的含义和原理 含义: FIFO:First In First Out,先进先出 LRU:Least Recently Used,最近最少使用 LFU:Lea...

FIFO、LRU、OPT这三种置换算法的缺页次数

考虑下述页面走向:           1,2,3,4,2,1,5,6,2,1,2,3,7,6,3,2,1,2,3,6      当内存块数量分别为3时,试...

用LinkedHashMap实现FIFO、LRU

用LinkedHashMap实现FIFO、LRU 来源:http://www.xymyeah.com/272.html HashMap与LinkedHashMap最大的不同在于,后者维护者...

LRU缓存实现(Java)

原文地址:http://www.cnblogs.com/lzrabbit/p/3734850.html#f1**注:此文章属懒惰的肥兔原创,版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)