Guava Cache淘汰算法

Guava Cache 使用的淘汰算法是 "基于访问顺序的近似 LRU,具体来说是一种分段 LRU" 实现,注意是近似LRU。

Guava Cache 借鉴了 ConcurrentHashMap的分段锁思想,将缓存分成多个 "Segment"(段),每个 Segment 内部维护自己的访问队列,实现独立的 LRU 淘汰。

数据结构设计

每个 Segment 内部维护两个双向链表

java 复制代码
// 简化的数据结构示意
class Segment<K, V> {
    // 基于访问顺序的双向链表(LRU核心)
    @Nullable ReferenceEntry<K, V> accessQueueHead;  头部
    @Nullable ReferenceEntry<K, V> accessQueueTail;  尾部
  
    // 基于写入顺序的双向链表(用于过期策略)
    @Nullable ReferenceEntry<K, V> writeQueueHead;   头部
    @Nullable ReferenceEntry<K, V> writeQueueTail;   尾部
}

访问顺序维护

当缓存项被访问时(读或写),Guava 会将其移动到访问队列的尾部"(MRU 端):

java 复制代码
// 伪代码:记录访问
void recordAccess(ReferenceEntry<K, V> entry) {
    // 从当前位置移除
    evictFromAccessQueue(entry);
    // 添加到尾部(最近使用)
    addToAccessQueue(entry);
}

淘汰发生在写入新数据时,当缓存大小超过限制:

java 复制代码
// 伪代码:淘汰过程
void evictEntries() {
    if (!overMaximumSize()) {
        return; // 未超限,不淘汰
    }
    
    // 从访问队列头部(LRU端)开始淘汰
    ReferenceEntry<K, V> eldest = accessQueueHead;
    while (eldest != null && overMaximumSize()) {
        // 移除最久未使用的条目
        removeEntry(eldest, RemovalCause.SIZE);
        eldest = accessQueueHead; // 移动到下一个
    }
}

为什么是"近似"LRU?

Guava Cache 的 LRU 是近似的,主要原因:

1、并发性能优化:在并发环境下,为了减少锁竞争,访问记录的更新是延迟的:

java 复制代码
// 读操作时并不立即更新队列,而是先记录"可能需要更新"
void get(key) {
    Entry entry = findEntry(key);
    if (entry != null) {
        // 不是立即移动,而是设置标志位
        entry.setAccessTime(System.currentTimeMillis());
        // 实际的队列更新可能批量进行
    }
}

2、分段设计的影响

由于缓存被分成多个 Segment,每个 Segment 独立维护 LRU 队列。淘汰时:

1、优先淘汰访问频率最低的 Segment" 中的条目

2、而不是全局严格的 LRU 顺序

淘汰的过程案例

java 复制代码
初始: [A]
添加B: [A, B]        // A(最久), B(最新)
添加C: [A, B, C]     // A(最久), B, C(最新)
访问A: [B, C, A]     // B(最久), C, A(最新) - A被移到尾部
添加D: [C, A, D]     // 淘汰最久的B,添加D到尾部
相关推荐
We་ct9 分钟前
LeetCode 73. 矩阵置零:原地算法实现与优化解析
前端·算法·leetcode·矩阵·typescript
天赐学c语言9 分钟前
2.1 - 反转字符串中的单词 && 每个进程的内存里包含什么
c++·算法·leecode
程序员泠零澪回家种桔子11 分钟前
OpenManus开源自主规划智能体解析
人工智能·后端·算法
请注意这个女生叫小美14 分钟前
C语言 实例20 25
c语言·开发语言·算法
好学且牛逼的马15 分钟前
【Hot100|22-LeetCode 206. 反转链表 - 完整解法详解】
算法·leetcode·矩阵
hans汉斯17 分钟前
国产生成式人工智能解决物理问题能力研究——以“智谱AI”、“讯飞星火认知大模型”、“天工”、“360智脑”、“文心一言”为例
大数据·人工智能·算法·aigc·文心一言·汉斯出版社·天工
v_for_van20 分钟前
力扣刷题记录3(无算法背景,纯C语言)
c语言·算法·leetcode
ValhallaCoder24 分钟前
hot100-矩阵
数据结构·python·算法·矩阵
散峰而望25 分钟前
【基础算法】穷举的艺术:在可能性森林中寻找答案
开发语言·数据结构·c++·算法·随机森林·github·动态规划
心.c27 分钟前
Vue3+Node.js实现文件上传分片上传和断点续传【详细教程】
前端·javascript·vue.js·算法·node.js·哈希算法