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

Hutool - Cache:简单而强大的缓存实现

目录

1. 缓存简介

2. 引入依赖

3. 常见缓存类型及使用示例

3.1 FIFO 缓存(先进先出缓存)

3.2 LRU 缓存(最近最少使用缓存)

3.3 定时缓存

4. 缓存的基本操作

5. 总结


1. 缓存简介

在软件开发中,缓存是一种常用的技术,用于减少对频繁访问的数据的重复计算或查询,从而提高系统的性能和响应速度。Hutool - Cache 是 Hutool 工具包中的一个模块,它提供了多种简单易用的缓存实现,能满足不同场景下的缓存需求。

2. 引入依赖

如果你使用 Maven 管理项目,在 pom.xml 中添加以下依赖:

 
<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>5.8.16</version>
</dependency>

3. 常见缓存类型及使用示例

3.1 FIFO 缓存(先进先出缓存)

FIFO(First In First Out)缓存按照元素插入的顺序,当缓存满时,最早插入的元素会被优先移除。

 
import cn.hutool.cache.Cache;
import cn.hutool.cache.impl.FIFOCache;

public class FIFOCacheExample {
    public static void main(String[] args) {
        // 创建一个容量为 3 的 FIFO 缓存
        Cache<String, String> fifoCache = new FIFOCache<>(3);

        // 向缓存中添加元素
        fifoCache.put("key1", "value1");
        fifoCache.put("key2", "value2");
        fifoCache.put("key3", "value3");

        // 此时缓存已满,再添加元素会移除最早插入的元素
        fifoCache.put("key4", "value4");

        // 获取缓存中的元素
        String value = fifoCache.get("key1");
        System.out.println("key1 的值: " + value); // 输出 null,因为 key1 已被移除

        value = fifoCache.get("key4");
        System.out.println("key4 的值: " + value); // 输出 value4
    }
}

3.2 LRU 缓存(最近最少使用缓存)

LRU(Least Recently Used)缓存会优先移除最近最少使用的元素,当缓存满时,最久未被访问的元素会被移除。

 
import cn.hutool.cache.Cache;
import cn.hutool.cache.impl.LRUCache;

public class LRUCacheExample {
    public static void main(String[] args) {
        // 创建一个容量为 3 的 LRU 缓存
        Cache<String, String> lruCache = new LRUCache<>(3);

        // 向缓存中添加元素
        lruCache.put("key1", "value1");
        lruCache.put("key2", "value2");
        lruCache.put("key3", "value3");

        // 访问 key1
        lruCache.get("key1");

        // 此时缓存已满,再添加元素会移除最近最少使用的元素
        lruCache.put("key4", "value4");

        // 获取缓存中的元素
        String value = fifoCache.get("key2");
        System.out.println("key2 的值: " + value); // 输出 null,因为 key2 是最近最少使用的元素,已被移除

        value = fifoCache.get("key4");
        System.out.println("key4 的值: " + value); // 输出 value4
    }
}

3.3 定时缓存

定时缓存会为每个元素设置一个过期时间,当元素过期后,会自动从缓存中移除。

 
import cn.hutool.cache.Cache;
import cn.hutool.cache.impl.TimedCache;
import java.util.concurrent.TimeUnit;

public class TimedCacheExample {
    public static void main(String[] args) throws InterruptedException {
        // 创建一个定时缓存,过期时间为 2 秒
        TimedCache<String, String> timedCache = new TimedCache<>(2000);

        // 向缓存中添加元素
        timedCache.put("key1", "value1");

        // 获取缓存中的元素
        String value = timedCache.get("key1");
        System.out.println("key1 的值: " + value); // 输出 value1

        // 等待 3 秒,让元素过期
        TimeUnit.SECONDS.sleep(3);

        // 再次获取缓存中的元素
        value = timedCache.get("key1");
        System.out.println("key1 的值: " + value); // 输出 null,因为元素已过期
    }
}

4. 缓存的基本操作

除了上述不同类型的缓存创建和使用,Hutool - Cache 还提供了一些基本的缓存操作方法:

  • put(key, value):向缓存中添加元素。

  • get(key):从缓存中获取元素,如果元素不存在则返回 null

  • remove(key):从缓存中移除指定键的元素。

  • containsKey(key):判断缓存中是否包含指定键的元素。

  • clear():清空缓存中的所有元素。

5. 总结

Hutool - Cache 提供了多种简单易用的缓存实现,通过不同的缓存策略可以满足不同场景下的缓存需求。在实际开发中,可以根据具体的业务需求选择合适的缓存类型,并利用其提供的基本操作方法来管理缓存数据,从而提高系统的性能和响应速度。

=============================end===================================

最后

好了,本文到此结束,希望本文对你有所帮助 😃

大家点赞、收藏、关注、评论啦 👇🏻 精彩专栏推荐订阅:在下方专栏👇🏻

偷偷的学Java

Java业务系统应用技术


http://www.kler.cn/a/547661.html

相关文章:

  • 华为最新OD机试真题-最长子字符串的长度(一)-Python-OD统一考试(E卷)
  • 【广州大学主办,发表有保障 | IEEE出版,稳定EI检索,往届见刊后快至1个月检索】第二届电气技术与自动化工程国际学术会议 (ETAE 2025)
  • ABP - 事件总线之分布式事件总线
  • 讯方·智汇云校华为授权培训机构的介绍
  • 洗牌加速!车规MCU“冷热交加”
  • AI技术+Xsens惯性捕捉技术:科技碰撞下的无限可能
  • 4G模块非必要,不关机!关机建议先进飞行模式
  • 【动态规划】详解 0-1背包问题
  • 题解:洛谷 P4113 [HEOI2012] 采花
  • Pytorch深度学习教程_2_Numpy数值计算
  • 计算机性能与网络体系结构探讨 —— 基于《计算机网络》谢希仁第八版
  • 中国AI“拥抱开源”给世界的启示——Anko
  • CAS单点登录(第7版)12.密码管理
  • markdown|mermaid|typora绘制流程图的连接线类型怎么修改?
  • 【STM32】增量型旋钮编码器
  • 伪装目标检测(Camouflaged Object Detection, COD)教程
  • 使用llama.cpp在gpu和cpu上运行deepseek-r1 7b的性能对比
  • 【日常经验】五种密码加密方式比较
  • 基于Qt 和微信小程序的用户管理系统:WebSocket + SQLite 实现注册与登录
  • JVM 底层探秘:对象创建的详细流程、内存分配机制解析以及线程安全保障策略