[互联网面试笔试汇总C/C++-21] FIFO 、LRU、LFU的含义、原理和实现-完美世界
来源:互联网 发布:mac windows系统黑屏 编辑:程序博客网 时间:2024/05/29 17:08
题目:请简要介绍FIFO、LRU、LFU的含义和原理
含义:
FIFO:First In First Out,先进先出
LRU:Least Recently Used,最近最少使用
LFU:Least Frequently Used,最不经常使用
以上三者都是缓存过期策略。
原理和实现:
如下图:
1. 新访问的数据插入FIFO队列尾部,数据在FIFO队列中顺序移动;
2. 淘汰FIFO队列头部的数据;
二、LRU(Least recently used,最近最少使用)算法根据数据的历史访问记录来进行淘汰数据,其核心思想是“如果数据最近被访问过,那么将来被访问的几率也更高”。
最常见的实现是使用一个链表保存缓存数据,详细算法实现如下:
1. 新数据插入到链表头部;
2. 每当缓存命中(即缓存数据被访问),则将数据移到链表头部;
3. 当链表满的时候,将链表尾部的数据丢弃。
三、LFU(Least Frequently Used)算法根据数据的历史访问频率来淘汰数据,其核心思想是“如果数据过去被访问多次,那么将来被访问的频率也更高”。
LFU的每个数据块都有一个引用计数,所有数据块按照引用计数排序,具有相同引用计数的数据块则按照时间排序。
具体实现如下:
1. 新加入数据插入到队列尾部(因为引用计数为1);
2. 队列中的数据被访问后,引用计数增加,队列重新排序;
3. 当需要淘汰数据时,将已经排序的列表最后的数据块删除。
注:以上图片摘自网络
- [互联网面试笔试汇总C/C++-21] FIFO 、LRU、LFU的含义、原理和实现-完美世界
- FIFO、LRU、LFU的含义和原理
- FIFO、LRU、LFU的含义和原理
- FIFO、LRU、LFU的含义和原理
- [互联网面试笔试汇总C/C++-22] 拷贝构造函数调用的时机-完美世界
- [互联网面试笔试汇总C/C++-24] Linux守护进程工作原理和方式-雅虎
- 简单的java缓存实现(LRU,LFU,FIFO)
- [互联网面试笔试汇总C/C++-4] 进程和线程的区别
- [互联网面试笔试汇总C/C++-19] 指针和引用的区别
- [互联网面试笔试汇总C/C++-2] 网易有道-1
- [互联网面试笔试汇总C/C++-3] 网易有道-2
- [互联网面试笔试汇总C/C++-5] 网易有道-3
- [互联网面试笔试汇总C/C++-6] 迅雷
- [互联网面试笔试汇总C/C++-18] 生产者消费者模型
- [互联网面试笔试汇总C/C++-6] 迅雷
- [互联网面试笔试汇总C/C++-9] 实现赋值运算符函数-剑指offer
- [互联网面试笔试汇总C/C++-11] 字符串全排列和组合算法
- [互联网面试笔试汇总C/C++-7] 堆栈的区别-百度
- LBP local binary patterns 人脸特征提取方法
- 芒果PPT助手在POWERPOINT中的使用
- 『图形图像』bmp2jpg的c代码
- 新手,帮看看这到底为什么报错
- MySQL5.5加主键锁读问题
- [互联网面试笔试汇总C/C++-21] FIFO 、LRU、LFU的含义、原理和实现-完美世界
- ID2D1Device 介绍
- php 日期
- Scaleform GFx之UDK教程
- flex基础篇二 flex加载数据的两种方式,httpService和本地xml
- jquery 异步上传
- Sql server 事务的两种用法
- c3p0数据源的配置
- ECSHOP模板js调用PHP数组