网易首页 > 网易号 > 正文 申请入驻

LRU(Least Recently Used)缓存算法的实现

0
分享至

作者:LuckDay 来源:JavaScript忍者秘籍

LRU就是Least Recently Used,即最近最少使用,是一种常用的页面置换算法,将最近长时间未使用的页面淘汰,其实也很简单,就是要将不受欢迎的页面及时淘汰,不让它占着茅坑不拉shit,浪费资源。

LRU是一种常见的页面置换算法,在计算中,所有的文件操作都要放在内存中进行,然而计算机内存大小是固定的,所以我们不可能把所有的文件都加载到内存,因此我们需要制定一种策略对加入到内存中的文件进行选择。

常见的页面置换算法有如下几种:

  • ●LRU 最近最久未使用
  • ●FIFO 先进先出置换算法 类似队列
  • ●OPT 最佳置换算法 (理想中存在的)
  • ●NRU Clock置换算法
  • ●LFU 最少使用置换算法
  • ●PBA 页面缓冲算法

LRU原理

LRU的设计原理就是,当数据在最近一段时间经常被访问,那么它在以后也会经常被访问。这就意味着,如果经常访问的数据,我们需要让其能够快速命中,而不常访问的数据,我们在容量超出限制内,要将其淘汰。

其核心就是利用栈,进行操作,其中主要有两项操作,get和put

get

get时,若栈中有值则将该值的key提到栈顶,没有时则返回null

put

栈未满时,若栈中有要put的key,则更新此key对应的value,并将该键值提到栈顶,若无要put的key,直接入栈

栈满时,若栈中有要put的key,则更新此key对应的value,并将该键值提到栈顶;若栈中没有put的key 时,去掉栈底元素,将put的值入到栈顶

解法:维护一个数组,提供 get 和 put 方法,并且限定 max 数量。

使用时,get 可以标记某个元素是最新使用的,提升它去第一项。put 可以加入某个key-value,但需要判断是否已经到最大限制 max

若未到能直接往数组第一项里插入 若到了最大限制 max,则需要淘汰数据尾端一个元素。

LRUCache cache = new LRUCache( 2 /* 缓存容量 */ );
cache.put(1, 1);
cache.put(2, 2);
cache.get(1); // 返回 1
cache.put(3, 3); // 该操作会使得密钥 2 作废
cache.get(2); // 返回 -1 (未找到)
cache.put(4, 4); // 该操作会使得密钥 1 作废
cache.get(1); // 返回 -1 (未找到)
cache.get(3); // 返回 3
cache.get(4); // 返回 4

LRU 算法设计

分析上面的操作过程,要让 put 和 get 方法的时间复杂度为 O(1),我们可以总结出 cache 这个数据结构必要的条件:查找快,插入快,删除快,有顺序之分。

因为显然 cache 必须有顺序之分,以区分最近使用的和久未使用的数据;而且我们要在 cache 中查找键是否已存在;如果容量满了要删除最后一个数据;每次访问还要把数据插入到队头。

那么,什么数据结构同时符合上述条件呢?哈希表查找快,但是数据无固定顺序;链表有顺序之分,插入删除快,但是查找慢。所以结合一下,形成一种新的数据结构:哈希链表。

LRU 缓存算法的核心数据结构就是哈希链表,双向链表和哈希表的结合体。这个数据结构长这样:

js 实现

  • 具体代码 一般的解法,通过维护一个数组,数组项存放了 key-value 键值对对象,每次需要遍历去寻找 key 值所在的数组下标操作。

已经通过 leetCode 146 的检测。执行用时 : 720 ms。内存消耗 : 58.5 MB。

function LRUCache(capacity) {
this.capacity = capacity; // 最大限制
this.cache = [];
};
/**
* @param {number} key
* @return {number}
*/
LRUCache.prototype.get = function (key) {
let index = this.cache.findIndex((item) => item.key === key);
if (index === -1) {
return -1;
}
// 删除此元素后插入到数组第一项
let value = this.cache[index].value;
this.cache.splice(index, 1);
this.cache.unshift({
key,
value,
});
return value;
};
/**
* @param {number} key
* @param {number} value
* @return {void}
*/
LRUCache.prototype.put = function (key, value) {
let index = this.cache.findIndex((item) => item.key === key);
// 想要插入的数据已经存在了,那么直接提升它就可以
if (index > -1) {
this.cache.splice(index, 1);
} else if (this.cache.length >= this.capacity) {
// 若已经到达最大限制,先淘汰一个最久没有使用的
this.cache.pop();
}
this.cache.unshift({ key, value });
};

上面的做法其实有变种,可以通过一个对象来存键值对,一个数组来存放键的顺序。

  • 进阶要求O(1)

时间复杂度 O(1),那就不能数组遍历去查找 key 值。可以用 ES6 的 Map 来解了,因为 Map 既能保持键值对,还能记住插入顺序。

function LRUCache(capacity) {
this.cache = new Map();
this.capacity = capacity; // 最大限制
};
LRUCache.prototype.get = function (key) {
if (this.cache.has(key)) {
// 存在即更新
let temp = this.cache.get(key);
this.cache.delete(key);
this.cache.set(key, temp);
return temp;
}
return -1;
};
LRUCache.prototype.put = function (key, value) {
if (this.cache.has(key)) {
// 存在即更新(删除后加入)
this.cache.delete(key);
} else if (this.cache.size >= this.capacity) {
// 不存在即加入
// 缓存超过最大值,则移除最近没有使用的
this.cache.delete(this.cache.keys().next().value);
}
this.cache.set(key, value);
};

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
给人养了7年闲人,广汽终于要关闭洛杉矶的研发中心

给人养了7年闲人,广汽终于要关闭洛杉矶的研发中心

与车同乐
2025-12-04 10:05:02
鸠山由纪夫戳破真相,当年免掉千亿赔款,实则给日本立了个死规定

鸠山由纪夫戳破真相,当年免掉千亿赔款,实则给日本立了个死规定

云霄纪史观
2026-05-20 13:16:50
三声警报拉响,全球资本市场风险四起

三声警报拉响,全球资本市场风险四起

魏家东
2026-05-20 12:11:01
张雪机车车队聚餐照片流出!一个个笑容满面,瓦嫂嘴角根本压不住

张雪机车车队聚餐照片流出!一个个笑容满面,瓦嫂嘴角根本压不住

火山詩话
2026-05-19 19:22:02
美股全线下跌,谷歌、亚马逊跌超2%,高通跌近4%,金银原油集体下挫

美股全线下跌,谷歌、亚马逊跌超2%,高通跌近4%,金银原油集体下挫

每日经济新闻
2026-05-20 16:50:07
被遗忘的库页岛中国百姓 当年他们在沙俄刺刀下生活

被遗忘的库页岛中国百姓 当年他们在沙俄刺刀下生活

那些看得见的老照片
2026-05-16 17:00:08
何意味?维尼修斯前女友晒亲吻猴子:这一下抓得也太紧了吧

何意味?维尼修斯前女友晒亲吻猴子:这一下抓得也太紧了吧

懂球帝
2026-05-20 15:05:07
独行侠总裁乌杰里:解雇基德是我的决定

独行侠总裁乌杰里:解雇基德是我的决定

星河漫山野
2026-05-21 01:11:12
“最佳血压” 是多少?建议:过 75 岁以后,血压最好保持这标准

“最佳血压” 是多少?建议:过 75 岁以后,血压最好保持这标准

任医生聊健康
2026-05-19 13:46:10
鲁比奥说了实话:不是因为台湾距离太远,而是美军真的打不赢!

鲁比奥说了实话:不是因为台湾距离太远,而是美军真的打不赢!

阿龙聊军事
2026-05-20 16:40:25
监狱来的妈妈第三波后续来了

监狱来的妈妈第三波后续来了

大张的自留地
2026-05-20 13:09:42
阵雨、雷雨!雨量中等!江苏天气最新预测

阵雨、雷雨!雨量中等!江苏天气最新预测

江南晚报
2026-05-21 03:32:53
白宫新宴会厅预算从2亿美元飙升至14亿,特朗普:这全是我和捐赠者的钱,并称这是“送给美国的礼物”

白宫新宴会厅预算从2亿美元飙升至14亿,特朗普:这全是我和捐赠者的钱,并称这是“送给美国的礼物”

大象新闻
2026-05-20 17:46:06
女篮世界杯赛程出炉!中国球迷又要熬夜:生死战被安排在凌晨2点

女篮世界杯赛程出炉!中国球迷又要熬夜:生死战被安排在凌晨2点

篮球快餐车
2026-05-20 05:37:22
汪小菲成功逆袭!资产飙到 25-30 亿,开劳斯莱斯,马筱梅是幕后功臣

汪小菲成功逆袭!资产飙到 25-30 亿,开劳斯莱斯,马筱梅是幕后功臣

八卦王者
2026-05-19 15:45:14
马斯克连骂7天,诺兰新片选角惹怒保守派

马斯克连骂7天,诺兰新片选角惹怒保守派

热搜摘要官
2026-05-20 02:22:42
家属大闹要投诉,护士委屈落泪,主任:我不收有医闹隐患的患者

家属大闹要投诉,护士委屈落泪,主任:我不收有医闹隐患的患者

健身狂人
2026-05-20 08:45:29
中超巅峰战变“碎玻璃渣”!李海新灾难级执法毁掉焦点对决!

中超巅峰战变“碎玻璃渣”!李海新灾难级执法毁掉焦点对决!

田先生篮球
2026-05-20 05:19:05
退休后才明白:那些从不刷存在感、不晒生活、连朋友圈都懒得发的人,往往在这两件事上甩开所有人,观察几十年从未例外

退休后才明白:那些从不刷存在感、不晒生活、连朋友圈都懒得发的人,往往在这两件事上甩开所有人,观察几十年从未例外

心理观察局
2026-05-19 07:06:14
赖清德,极有可能是1949年以来,唯一在任上出事的台湾地区领导人

赖清德,极有可能是1949年以来,唯一在任上出事的台湾地区领导人

混沌录
2026-05-19 19:56:10
2026-05-21 05:11:00
Nodejs开发
Nodejs开发
分享只有程序员懂的干货
648文章数 823关注度
往期回顾 全部

科技要闻

一文看懂谷歌I/O2026:谷歌打响智能体大战

头条要闻

被普京抱过的中国男孩火了 本人最新发声

头条要闻

被普京抱过的中国男孩火了 本人最新发声

体育要闻

尼克斯赢下最窒息的一场翻盘,场场都是逆天局

娱乐要闻

王菲“没事儿”,成年人学不来的松弛

财经要闻

白酒榜|汾酒营收净利双增 口子窖"造富"

汽车要闻

26.98万起步 看小鹏GX如何诠释一车多能以及满配的科技与豪华

态度原创

时尚
亲子
数码
教育
本地

被这个颜色刷屏了!今年夏天想减龄好看就穿它吧

亲子要闻

孩子零食肉干掉地上蚂蚁吃完全死了!家长慌了:天天给娃吃的啊!

数码要闻

华为MatePad Pro Max国内官宣预售,以"极致"拓展旗舰平板体验边界

教育要闻

最新:科利华初中、玄外附小有变化!

本地新闻

用云锦的方式,打开江苏南京

无障碍浏览 进入关怀版