讲述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();
相关推荐
烂蜻蜓1 小时前
前端已死?什么是前端
开发语言·前端·javascript·vue.js·uni-app
老猿讲编程1 小时前
安全C语言编码规范概述
c语言·开发语言·安全
陌殇殇1 小时前
002 SpringCloudAlibaba整合 - Feign远程调用、Loadbalancer负载均衡
java·spring cloud·微服务
猎人everest2 小时前
SpringBoot应用开发入门
java·spring boot·后端
web135085886352 小时前
Python大数据可视化:基于python的电影天堂数据可视化_django+hive
python·信息可视化·django
东方芷兰2 小时前
伯克利 CS61A 课堂笔记 11 —— Mutability
笔记·python
山猪打不过家猪4 小时前
ASP.NET Core Clean Architecture
java·数据库·asp.net
AllowM4 小时前
【LeetCode Hot100】除自身以外数组的乘积|左右乘积列表,Java实现!图解+代码,小白也能秒懂!
java·算法·leetcode
Biomamba生信基地4 小时前
两天入门R语言,周末开讲
开发语言·r语言·生信
RAN_PAND4 小时前
STL介绍1:vector、pair、string、queue、map
开发语言·c++·算法