LRU、LFU、FIFO算法总结
2016-08-29 21:49
477 查看
一、概述
(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
相关文章推荐
- 缓存算法(内存回收算法)- LRU、FIFO、LFU
- FIFO 、LRU、LFU三种算法
- FIFO 、LRU、LFU三种算法
- OPT算法,FIFO算法,LRU算法,LFU算法的java程序
- 缓存失效策略(FIFO 、LRU、LFU三种算法的区别)
- FIFO 、LRU、LFU三种算法
- 缓存回收算法 FIFO 、LRU、LFU三种算法
- 缓存算法(内存回收算法)- LRU、FIFO、LFU
- 常用缓存淘汰算法(LFU、LRU、ARC、FIFO、MRU)
- FIFO 、LRU、LFU三种算法
- 关于FIFO 、LRU、LFU三种算法
- 缓存失效策略(FIFO 、LRU、LFU三种算法的区别)
- 数据缓存失效算法FIFO、LRU、LFU深入理解
- FIFO、LRU、OPT这三种置换算法的缺页次数
- LRU和FIFO算法的页面调度举例
- 缓存算法(页面置换算法)-FIFO、LFU、LRU
- FIFO、LFU、LRU三种缓存策略之间的区别
- 页置换算法FIFO、LRU、OPT
- [互联网面试笔试汇总C/C++-21] FIFO 、LRU、LFU的含义、原理和实现-完美世界
- 淘汰算法LRU与LFU