【工具篇】使用concurrentHashMap实现缓存工具类

📢📢📢📣📣📣

哈喽!大家好,今天给大家带来一个使用concurrentHashMap封装的缓存工具类,并提供了常用的方法:存入缓存、查找缓存、删除缓存、获取缓存大小等等;

✨个人博客:https://blog.csdn.net/weixin_43759352

✨公众号:【SimpleMemory】✨

❤️❤️❤️如果有对【后端技术】感兴趣的大佬们,欢迎关注!!!❤️❤️❤️ 

示例代码:

import lombok.extern.slf4j.Slf4j;
import java.util.*;
import java.util.concurrent.*;

/**
 * @author xxkfz
 * 自定义缓存
 */
@Slf4j
public class ConcurrentHashMapCache {

    private final Map<String, Object> CACHE_MAP = new ConcurrentHashMap<String, Object>();

    /**
     * 每个缓存生效时间12小时
     */
    public final long CACHE_HOLD_TIME_12H = 12 * 60 * 60 * 1000L;

    /**
     * 每个缓存生效时间24小时
     */
    public final long CACHE_HOLD_TIME_24H = 24 * 60 * 60 * 1000L;

    /**
     * 存放一个缓存对象,默认保存时间12小时
     *
     * @param cacheName
     * @param obj
     */
    public void put(String cacheName, Object obj) {
        put(cacheName, obj, CACHE_HOLD_TIME_12H);
    }

    /**
     * 存放一个缓存对象,保存时间为holdTime
     *
     * @param cacheName
     * @param obj
     * @param holdTime
     */
    public void put(String cacheName, Object obj, long holdTime) {
        CACHE_MAP.put(cacheName, obj);
        // 设置缓存失效时间
        CACHE_MAP.put(cacheName + "_HoldTime", System.currentTimeMillis() + holdTime);
        log.info("{}:成功存入缓存! 过期时间:{}", cacheName, holdTime);
    }

    /**
     * 取出一个缓存对象
     *
     * @param cacheName
     * @return
     */
    public Object get(String cacheName) {
        if (checkCacheName(cacheName)) {
            return CACHE_MAP.get(cacheName);
        }
        return null;
    }

    /**
     * 删除所有缓存
     */
    public void removeAll() {
        CACHE_MAP.clear();
    }

    /**
     * 删除某个缓存
     *
     * @param cacheName
     */
    public void remove(String cacheName) {
        CACHE_MAP.remove(cacheName);
        CACHE_MAP.remove(cacheName + "_HoldTime");
    }

    /**
     * 检查缓存对象是否存在,
     * 若不存在,则返回false
     * 若存在,检查其是否已过有效期,如果已经过了则删除该缓存并返回false
     *
     * @param cacheName
     * @return
     */
    public boolean checkCacheName(String cacheName) {
        Long cacheHoldTime = (Long) CACHE_MAP.get(cacheName + "_HoldTime");
        if (cacheHoldTime == null || cacheHoldTime == 0L) {
            return false;
        }
        if (cacheHoldTime < System.currentTimeMillis()) {
            log.info("缓存:{}已失效!", cacheName);
            remove(cacheName);
            return false;
        }
        return true;
    }

    /**
     * 获取缓存大小
     *
     * @return
     */
    public Integer size() {
        if (null != CACHE_MAP && CACHE_MAP.size() > 0) {
            return CACHE_MAP.size();
        }
        return 0;
    }

    /**
     * 判断缓存的key是否存在
     *
     * @param cacheName
     * @return
     */
    public boolean isExist(String cacheName) {
        if (!checkCacheName(cacheName)) {
            return Boolean.FALSE;
        }
        return CACHE_MAP.containsKey(cacheName);
    }
}

如果这篇【文章】对您有帮助,希望大家点赞、评论、关注、收藏;如果对【后端技术】感兴趣的小可爱,也欢迎关注❤️❤️❤️ 公众号【SimpleMemory】❤️❤️❤️,将会继续给大家带来【收获与惊喜】💕💕!

在Spring Boot应用中,ConcurrentHashMap并不是用来实现`Context`(上下文)的一部分,而是Java并发工具包中的一个数据结构,用于高效地存储键值对并且保证线程安全。它允许高并发环境下的读写操作,因为它的内部结构设计了锁的粒度更细,降低了锁定范围,提高了并发性能。 如果你想在Spring Boot应用中使用`ConcurrentHashMap`来存储某种类型的上下文数据,比如Spring Application Context中的bean信息,你可以这样做: 1. 首先,定义一个自定义的Map,比如`MyApplicationContext`: ```java import java.util.concurrent.ConcurrentHashMap; public class MyApplicationContext extends ConcurrentHashMap<String, Object> { // 添加其他需要的方法,如初始化、获取、设置key-value等 } ``` 2. 然后,可以在Spring的`ApplicationContextInitializer`或`ApplicationListener`里,创建并初始化这个`MyApplicationContext`实例: ```java @Autowired private void initializeApplicationContext(ApplicationContext applicationContext) { MyApplicationContext myContext = new MyApplicationContext(); // 将applicationContext中的bean信息添加到myContext中 for (String beanName : applicationContext.getBeanDefinitionNames()) { myContext.put(beanName, applicationContext.getBean(beanName)); } } ``` 3. 记得在Spring的配置中启用该实现,如`@Configuration`类中: ```java @Configuration public class AppConfig { @Bean public MyApplicationContext customApplicationContext() { return new MyApplicationContext(); } } ``` 这只是一个基本示例,实际使用可能会根据需求定制更多的功能,比如缓存策略、生命周期管理等。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小小Java开发者

“是一种鼓励,你懂的”

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值