讲述java中常见的几种缓存数据形式 并简单演示

1、HashMap

HashMap是Java中最常用的缓存数据的方式之一。它使用键值对的方式存储数据,通过键来快速查找和获取对应的值。可以使用put方法将数据放入HashMap中,使用get方法来获取数据。

只要没有手动删除或程序终止运行,缓存信息会一直存在

定义一个HashMap集合方式

java 复制代码
Map<String, String> 集合名称 = new HashMap<>();

加入数据

java 复制代码
cache.put("键", "值");

获取缓存数据

java 复制代码
集合名称.get("键");

根据键删除指定数据

java 复制代码
集合名.remove("键");

清空全部数据

java 复制代码
集合名..clear();

参考整体代码如下

java 复制代码
//定义一个HashMap  名称cache
Map<String, String> cache = new HashMap<>();
//向cache中添加一条数据 键key1 值value1
cache.put("key1", "value1");
//用System.out.println 输出键为key1的这条数据的值
System.out.println(cache.get("key1"));
//删除 键为 key1 的这一条数据
cache.remove("key1");
//用System.out.println 输出键为key1的这条数据的值 此时因为已经删除 值应该是null
System.out.println(cache.get("key1"));
//删除cache内所有的数据
cache.clear();

2、ConcurrentHashMap

ConcurrentHashMap是HashMap的线程安全版本,适用于多线程环境下的缓存操作。它使用分段锁来提高并发性能,不同的线程可以同时访问不同的分段,从而提高并发访问的效率。

ConcurrentHashMap 没有自动过期的设置 所以想让他自己过期你要自己写逻辑处理,然后他的消失情况除了项目停止运行之外还有就是当内存不足时系统操作会回收一些内存,就可能导致部分ConcurrentHashMap被回收

定义一个 ConcurrentHashMap 的方法

java 复制代码
ConcurrentMap<String, String> 名称 = new ConcurrentHashMap<>();

存入数据

java 复制代码
集合名称.put("键", "值");

取数据

java 复制代码
集合名称.get("键");

删除全局

java 复制代码
集合名称.clear();

参考代码如下

java 复制代码
//定义一个ConcurrentMap 名称cache
ConcurrentMap<String, String> cache = new ConcurrentHashMap<>();
//向cache中添加一条数据 键key1 值value1
cache.put("key1", "value1");
//用System.out.println 输出键为key1的这条数据的值
System.out.println(cache.get("key1"));
//删除 键为 key1 的这一条数据
cache.remove("key1");
//用System.out.println 输出键为key1的这条数据的值 此时因为已经删除 值应该是null
System.out.println(cache.get("key1"));
//删除cache内所有的数据
cache.clear();

3、Caffeine

Caffeine是一个高性能的缓存库,提供了各种缓存策略和配置选项。它可以自动管理缓存中的数据,包括过期时间、最大缓存大小等。

Caffeine有过期时间的设置,当达到时间则消失 内存超出时也会回收一定的Caffeine,当达到设置的大小之后Caffeine也会按照依据移除一些缓存 然后就是可以手动删除

要使用Caffeine需要注入依赖

xml 复制代码
<dependencies>
    <dependency>
        <groupId>com.github.ben-manes.caffeine</groupId>
        <artifactId>caffeine</artifactId>
        <version>2.9.0</version>
    </dependency>
</dependencies>

然后 定义一个

java 复制代码
Cache<String, String> cache = Caffeine.newBuilder()
                .expireAfterWrite(10, TimeUnit.MINUTES) // 设置缓存项的过期时间为10分钟
                .maximumSize(100) // 设置缓存容量为100
                .build();

这里 我们定义了一个 存在10分钟 存储100的缓存

名称为 cache

然后 存入数据 缓存名称.put("键","值")

java 复制代码
cache.put("key1", "value1");

获取数据 缓存名称.getIfPresent("键")

java 复制代码
System.out.println(cache.getIfPresent("key1"));

根据键删除指定数据 缓存名.invalidate("键");

java 复制代码
cache.invalidate("key1");

清除所有数据 缓存名.invalidateAll();

java 复制代码
cache.invalidateAll();

4、Ehcache

Ehcache是一个广泛使用的开源缓存库,支持分布式缓存、磁盘持久化等功能。它提供了丰富的配置选项和API,可以根据需求进行灵活的缓存管理。

此缓存的情况也差不多,可以设置过期时间 过期时间触发消失。 可手动删除消失。应用关闭后会消失。超过设置容量时 会按规范移除 内存超出时也会被回收一些

想使用Ehcache 需要注入依赖

xml 复制代码
 <dependency>
        <groupId>org.ehcache</groupId>
        <artifactId>ehcache</artifactId>
        <version>3.9.0</version>
    </dependency>

参考代码如下

java 复制代码
 // 创建一个CacheManager实例
CacheManager cacheManager = CacheManagerBuilder.newCacheManagerBuilder().build();
cacheManager.init();

// 创建一个Cache实例
Cache<String, String> cache = cacheManager.createCache("myCache",
        CacheConfigurationBuilder.newCacheConfigurationBuilder(String.class, String.class,
                ResourcePoolsBuilder.heap(100)));

// 向缓存中存放数据
cache.put("key", "value");

//用System.out.println 输出从cache中获取的指定键key对应的值
System.out.println(cache.get("key"));
//根据键key从缓存中删除指定数据
cache.remove("key");
//用System.out.println 输出从cache中获取的指定键key对应的值 因为已经删除此时应该是null
System.out.println(cache.get("key"));
//清空缓存
cacheManager.close();
相关推荐
老歌老听老掉牙9 分钟前
平面旋转与交线投影夹角计算
python·线性代数·平面·sympy
可乐加.糖12 分钟前
一篇关于Netty相关的梳理总结
java·后端·网络协议·netty·信息与通信
满怀101514 分钟前
Python入门(7):模块
python
无名之逆14 分钟前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust
s91236010114 分钟前
rust 同时处理多个异步任务
java·数据库·rust
9号达人15 分钟前
java9新特性详解与实践
java·后端·面试
你觉得20518 分钟前
哈尔滨工业大学DeepSeek公开课:探索大模型原理、技术与应用从GPT到DeepSeek|附视频与讲义下载方法
大数据·人工智能·python·gpt·学习·机器学习·aigc
cg501719 分钟前
Spring Boot 的配置文件
java·linux·spring boot
似水এ᭄往昔19 分钟前
【C语言】文件操作
c语言·开发语言
啊喜拔牙26 分钟前
1. hadoop 集群的常用命令
java·大数据·开发语言·python·scala