LRU 和 LFU 有啥区别

区别

LRU(The Least Recently Used),最近最少使用,最久未被访问的数据会被最早淘汰。
LFU(Least Frequently Used),最少频次使用,访问次数最少的数据会被最早淘汰。

LRU只关注数据最近一次被使用时间(时间越久、越容易被淘汰),LFU 只关注数据最近一段时间被使用的次数(次数越少,越容易被淘汰)。

假设缓存中数据使用顺序如下(从左到右表示时间从晚到早):

A、B、C、D、A、C、C、D

那么,如果按照LRU 淘汰的是,就淘汰那个最近一次使用时间更早的。即D
如果按照LFU 淘汰的是,就淘汰那个使用次数最少的。即B

LRU

LRU(The Least Recently Used,最近最少使用)是一种常见的缓存算法,在很多分布式缓存系统(如Redis, Memcached)中都有广泛使用。

LRU算法的思想是:如果一个数据在最近一段时间没有被访问到,那么可以认为在将来它被访问的可能性也很小。因此,当空间满时,最久没有访问的数据最先被淘汰。

最常见的实现是使用一个链表保存缓存数据,详细算法实现如下:

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

LFU

LFU(Least Frequently Used ,最少频次使用)也是一种常见的缓存算法。

顾名思义,LFU算法的思想是:如果一个数据在最近一段时间很少被访问到,那么可以认为在将来它被访问的可能性也很小。因此,当空间满时,最小频率访问的数据最先被淘汰。

LFU的每个数据块都有一个引用计数,所有数据块按照引用计数排序,具有相同引用计数的数据块则按照时间排序。



具体实现如下:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

埃泽漫笔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值