当前位置: 首页 > ds >正文

Guava 与 Caffeine 本地缓存系统详解

Guava 与 Caffeine 本地缓存系统详解

☘️ Guava Cache(Google 出品)

一、简介

Guava 是 Google 开源的 Java 核心库,提供了大量工具类、集合类扩展、缓存框架等。其中 com.google.common.cache.Cache 是其缓存组件。

二、核心特性

特性描述
支持手动加载与自动加载可以使用 Cache(手动)或 LoadingCache(自动)
过期策略基于时间(写入后 / 访问后)
最大容量控制支持基于容量的逐出(eviction)
移除监听器提供 RemovalListener
统计信息缓存命中率、加载时间等统计
并发性线程安全,但并发性能一般

三、典型用法示例

LoadingCache<String, String> cache = CacheBuilder.newBuilder().maximumSize(1000).expireAfterWrite(10, TimeUnit.MINUTES).removalListener(notification -> {System.out.println("移除原因:" + notification.getCause());}).build(new CacheLoader<String, String>() {@Overridepublic String load(String key) {return loadDataFromDB(key);}});// 获取值(自动加载)
String value = cache.get("key1");// 手动放入
cache.put("key2", "value2");

⚡ Caffeine(Guava 的升级版)

一、简介

Caffeine 是 Guava Cache 的接班人,由 Ben Manes 编写,其目标是提供更高性能、更多特性、更现代化的缓存实现。

二、核心优势

特性GuavaCaffeine
性能中等极高(接近 ConcurrentHashMap)
驱逐算法LRU(近似)Window TinyLFU(更智能)
支持异步✅(AsyncLoadingCache
写入策略写入后/访问后
缓存刷新支持 refreshAfterWrite✅(异步刷新)
弱/软引用
并发性能中等极好(基于分段机制)

三、核心用法示例

1. 同步加载缓存
LoadingCache<String, String> cache = Caffeine.newBuilder().maximumSize(1000).expireAfterWrite(10, TimeUnit.MINUTES).removalListener((String key, String value, RemovalCause cause) ->System.out.println("被移除 key=" + key + ", 原因=" + cause)).build(key -> loadDataFromDB(key));
2. 异步缓存(AsyncLoadingCache)
AsyncLoadingCache<String, String> asyncCache = Caffeine.newBuilder().maximumSize(1000).expireAfterWrite(10, TimeUnit.MINUTES).buildAsync(key -> CompletableFuture.supplyAsync(() -> loadDataFromDB(key)));

📊 Guava vs Caffeine 性能对比

  • Caffeine 的 TinyLFU 驱逐算法可以在高并发和高命中率下表现极佳。
  • 在 benchmark 中,Caffeine 的性能大约是 Guava 的 2~20 倍,特别是在多线程环境下优势更明显。

🧠 使用建议

使用场景推荐缓存库原因
单线程、轻量级缓存Guava实现简单、依赖少
高并发、性能敏感Caffeine极致性能、更强策略
需要异步加载CaffeineGuava 不支持异步加载
简单本地缓存Guava快速上手,文档齐全
大量数据缓存+智能淘汰Caffeine支持 TinyLFU,更智能

🔧 典型配置参数对比

参数名GuavaCaffeine
maximumSize
expireAfterAccess
expireAfterWrite
refreshAfterWrite
weakKeys / softValues
removalListener
recordStats()
build() / buildAsync()✅(同步)✅(支持异步)

📝 结语

  • Guava:适合一般场景,轻量级需求、快速接入。
  • Caffeine:适合高并发、对性能有严格要求的项目,是目前 Java 生态最强大的本地缓存方案。
http://www.xdnf.cn/news/17236.html

相关文章:

  • 2048小游戏
  • 【java】大数据insert的几种技术方案和优缺点
  • (ZipList入门笔记一)ZipList的节点介绍
  • Windows 电脑远程访问,ZeroTier 实现内网穿透完整指南(含原理讲解)
  • Spring Boot 整合 Web 开发全攻略
  • 深度拆解Dify:开源LLM开发平台的架构密码与技术突围
  • 消息队列疑难问题(RocketMQ)
  • 09-堆
  • GaussDB 常见问题-集中式
  • 8.5 CSS3多列布局
  • lumerical——Y分支功分器
  • Redis Stream:高性能消息队列核心原理揭秘
  • PDF转图片工具技术文档(命令行版本)
  • CRT调试堆检测:从原理到实战的资源泄漏排查指南
  • 北京JAVA基础面试30天打卡02
  • RocketMq如何保证消息的顺序性
  • 面向对象的七大设计原则
  • Kotlin属性委托
  • 探秘MOBILITY China 2026,新能源汽车与智慧出行的未来盛宴
  • React18 严格模式下的双重渲染之谜
  • 嵌入式硬件中运放的基本控制原理
  • 2025金九银十Java后端面试攻略
  • 天津大学2024-2025 预推免 机试题目(第二批)
  • 400V降24V,200mA,应用领域:从生活到工业的 “全能电源管家”
  • C++面向对象编程基础:从类定义到封装机制详解
  • 深度学习-卷积神经网络CNN-填充与步幅
  • 最新基于Python科研数据可视化实践技术
  • 【人工智能99问】什么是Post-Training,包含哪些内容?(19/99)
  • Next Terminal 实战:内网无密码安全登录
  • MCP进阶:工业协议与AI智能体的融合革命