数据缓存失效算法FIFO、LRU、LFU深入理解
2017-10-24 23:29
337 查看
题目:请简要介绍FIFO、LRU、LFU的含义和原理
含义:
FIFO:First
In First Out,先进先出
LRU:Least
Recently Used,最近最少使用
LFU:Least
Frequently Used,最不经常使用
以上三者都是缓存过期策略。
原理和实现:
一、FIFO按照“先进先出(First In,First Out)”的原理淘汰数据,正好符合队列的特性,数据结构上使用队列Queue来实现。
如下图:
1. 新访问的数据插入FIFO队列尾部,数据在FIFO队列中顺序移动;
2. 淘汰FIFO队列头部的数据;
二、LRU(Least recently used,最近最少使用)算法根据数据的历史访问记录来进行淘汰数据,其核心思想是“如果数据最近被访问过,那么将来被访问的几率也更高”。
最常见的实现是使用一个链表保存缓存数据,详细算法实现如下:
1. 新数据插入到链表头部;
2. 每当缓存命中(即缓存数据被访问),则将数据移到链表头部;
3. 当链表满的时候,将链表尾部的数据丢弃。
三、LFU(Least Frequently Used)算法根据数据的历史访问频率来淘汰数据,其核心思想是“如果数据过去被访问多次,那么将来被访问的频率也更高”。
LFU的每个数据块都有一个引用计数,所有数据块按照引用计数排序,具有相同引用计数的数据块则按照时间排序。
具体实现如下:
1. 新加入数据插入到队列尾部(因为引用计数为1);
2. 队列中的数据被访问后,引用计数增加,队列重新排序;
3. 当需要淘汰数据时,将已经排序的列表最后的数据块删除。
含义:
FIFO:First
In First Out,先进先出
LRU:Least
Recently Used,最近最少使用
LFU:Least
Frequently Used,最不经常使用
以上三者都是缓存过期策略。
原理和实现:
一、FIFO按照“先进先出(First In,First Out)”的原理淘汰数据,正好符合队列的特性,数据结构上使用队列Queue来实现。
如下图:
1. 新访问的数据插入FIFO队列尾部,数据在FIFO队列中顺序移动;
2. 淘汰FIFO队列头部的数据;
二、LRU(Least recently used,最近最少使用)算法根据数据的历史访问记录来进行淘汰数据,其核心思想是“如果数据最近被访问过,那么将来被访问的几率也更高”。
最常见的实现是使用一个链表保存缓存数据,详细算法实现如下:
1. 新数据插入到链表头部;
2. 每当缓存命中(即缓存数据被访问),则将数据移到链表头部;
3. 当链表满的时候,将链表尾部的数据丢弃。
三、LFU(Least Frequently Used)算法根据数据的历史访问频率来淘汰数据,其核心思想是“如果数据过去被访问多次,那么将来被访问的频率也更高”。
LFU的每个数据块都有一个引用计数,所有数据块按照引用计数排序,具有相同引用计数的数据块则按照时间排序。
具体实现如下:
1. 新加入数据插入到队列尾部(因为引用计数为1);
2. 队列中的数据被访问后,引用计数增加,队列重新排序;
3. 当需要淘汰数据时,将已经排序的列表最后的数据块删除。
相关文章推荐
- 缓存失效策略(FIFO 、LRU、LFU三种算法的区别)
- 缓存失效策略(FIFO 、LRU、LFU三种算法的区别)
- 常用缓存淘汰算法(LFU、LRU、ARC、FIFO、MRU)
- 缓存回收算法 FIFO 、LRU、LFU三种算法
- 深入理解【缺页中断】及FIFO、LRU、OPT这三种置换算法
- java动态缓存成长小纪(二)——缓存算法的实现:LRU、LFU、FIFO
- 关于缓存调度算法FIFO、LRU、OPT这三种置换算法的缺页次数
- FIFO 、LRU、LFU三种算法
- LRU、LFU、FIFO算法总结
- FIFO 、LRU、LFU三种算法
- 缓存淘汰算法 LFU and LRU
- 两种常见的缓存淘汰算法LFU&LRU
- 【转载】对用LRU和FIFO算法计算“缺页中断”的理解
- OPT算法,FIFO算法,LRU算法,LFU算法的java程序
- FIFO 、LRU、LFU三种算法
- 详解三种缓存过期策略LFU,FIFO,LRU(附带实现代码)
- 缓存淘汰算法--LRU算法【最近最少使用算法LRU置换策略适用于热点数据比较多的场景】
- 对用LRU和FIFO算法计算“缺页中断”的理解
- 简单的java缓存实现(LRU,LFU,FIFO)
- 缓存算法(内存回收算法)- LRU、FIFO、LFU