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

xxkfz
• 阅读 340

📢📢📢📣📣📣

哈喽!大家好,今天给大家带来一个使用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】❤️❤️❤️,将会继续给大家带来【收获与惊喜】💕💕!

点赞
收藏
评论区
推荐文章
光头强的博客 光头强的博客
2个月前
Java面向对象试题
1、 请创建一个Animal动物类,要求有方法eat()方法,方法输出一条语句“吃东西”。 创建一个接口A,接口里有一个抽象方法fly()。创建一个Bird类继承Animal类并实现 接口A里的方法输出一条有语句“鸟儿飞翔”,重写eat()方法输出一条语句“鸟儿 吃虫”。在Test类中向上转型创建b对象,调用eat方法。然后向下转型调用eat()方
九路 九路
2年前
6 手写Java LinkedHashMap 核心源码
概述 LinkedHashMap是Java中常用的数据结构之一,安卓中的LruCache缓存,底层使用的就是LinkedHashMap,LRU(Least Recently Used)算法,即最近最少使用算法,核心思想就是当缓存满时,会优先淘汰那些近期最少使用的缓存对象 LruCache的缓存算法 LruCache采用的缓存算法为LRU(Least Re
Wesley13 Wesley13
1年前
thinkphp缓存使用
thinkphp缓存使用 ============ 一、总结 ---- 1、这里的缓存不是指的缓存的页面,而是cache,如果你缓存了一个数组,那么你就可以取出这个数组里面的数据进行使用,用法性质和cookie和session有点像 2、缓存的数据可以在thinkphp的runtime下的cache文件夹下面找到 3、用法:可以用Cache类也可以用
Stella981 Stella981
1年前
Spring Cache缓存技术的介绍
缓存用于提升系统的性能,特别适用于一些对资源需求比较高的操作。本文介绍如何基于spring boot cache技术,使用caffeine作为具体的缓存实现,对操作的结果进行缓存。 demo场景 ====== 本demo将创建一个web应用,提供两个Rest接口。一个接口用于接受查询请求,并有条件的缓存查询结果。另一个接口用于获取所有缓存的数据,用于监控
Wesley13 Wesley13
1年前
Spring缓存机制的理解
在Spring缓存机制中,包括了两个方面的缓存操作:1.缓存某个方法返回的结果;2.在某个方法执行前或后清空缓存。 下面写两个类来模拟Spring的缓存机制: [![复制代码](http://static.oschina.net/uploads/img/201412/27165131_1BWJ.gif)](https://www.oschina.net/
Stella981 Stella981
1年前
Redis 缓存性能实践及总结
一、前言 ==== 在互联网应用中,缓存成为高并发架构的关键组件。这篇博客主要介绍缓存使用的典型场景、实操案例分析、Redis使用规范及常规 Redis 监控。 二、常见缓存对比 ======== 常见的缓存方案,有本地缓存,包括HashMap/ConcurrentHashMap、Ehcache、Memcache、Guava Cache等,缓存中间件包
Stella981 Stella981
1年前
Guava的两种本地缓存策略
Guava的两种缓存策略 ============ * * * 缓存在很多场景下都需要使用,如果电商网站的商品类别的查询,订单查询,用户基本信息的查询等等,针对这种读多写少的业务,都可以考虑使用到缓存。在一般的缓存系统中,除了分布式缓存,还会有多级缓存,在提升一定性能的前提下,可以在一定程度上避免缓存击穿或缓存雪崩,也能降低分布式缓存的负载。 Guav
Stella981 Stella981
1年前
Redis序列化操作工具
以往使用memcached。对于任意缓存的使用操作。 而今喜欢Redis。很多小伙伴用redis直接用字符串、json进行对象存储,然而序列化比较通用且性能高于json。  故此,封装了一个redis序列化操作工具,希望对小伙伴们有用。 package com.app.server.common.cache; import j
Stella981 Stella981
1年前
Mybatis(四)—— Mybatis 缓存
### 一、Mybatis 缓存 > MyBatis 包含一个非常强大的查询缓存特性,使用缓存可以使应用更快地获取数据,避免频繁的数据库交互 ### 二、Mybatis缓存分类 1. 一级缓存:SqlSession的缓存 > * 一级缓存默认会启用,想要关闭一级缓存可以在select标签上配置flushCache=“true”;
Wesley13 Wesley13
1年前
.NET中的本地缓存(数据分拆+lock锁)
本章将和大家分享.NET中的本地缓存。 本章将和大家分享如何使用数据分拆+lock锁的方式来实现本地缓存。 系统性能优化的第一步,就是使用缓存。缓存包括:客户端缓存---CDN缓存---反向代理缓存---本地缓存。 ![](https://static.oschina.net/uploads/img/202009/27220009_a8gt.png)