java内存缓存实现 与 redis缓存实现 (ConcurrentHashMap 应用)

java 复制代码
import org.springframework.stereotype.Service;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.function.Supplier;

@Service
public class LocalCacheService {

    // 核心内存缓存容器(线程安全的ConcurrentHashMap)
    private final Map<String, Object> localCache = new ConcurrentHashMap<>();

    /**
     * 通用内存缓存获取方法
     * @param cacheKey 缓存键
     * @param dataLoader 数据加载器(缓存未命中时执行)
     * @return 缓存或加载的数据
     */
    public <T> T getFromLocalCache(String cacheKey, Supplier<T> dataLoader) {
        // 1. 从内存缓存获取数据
        @SuppressWarnings("unchecked")
        T data = (T) localCache.get(cacheKey);

        // 2. 缓存命中,直接返回
        if (data != null) {
            return data;
        }

        // 3. 缓存未命中,执行数据加载逻辑
        data = dataLoader.get();

        // 4. 加载成功后放入内存缓存
        if (data != null) {
            localCache.put(cacheKey, data);
        }

        return data;
    }

    /**
     * 主动清除指定缓存
     * @param cacheKey 缓存键
     */
    public void removeLocalCache(String cacheKey) {
        localCache.remove(cacheKey);
    }

    /**
     * 清空所有内存缓存(谨慎使用)
     */
    public void clearAllLocalCache() {
        localCache.clear();
    }
}

上面的是 内存缓存

下面的是 redis缓存

java 复制代码
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Service;

import java.util.function.Supplier;

@Service
public class CacheService {

    @Autowired
    private RedisTemplate<String, Object> redisTemplate;

    /**
     * 通用缓存获取方法
     * @param cacheKey 缓存键
     * @param dataLoader 数据加载器函数
     * @return 缓存或数据库中的数据
     */
    public <T> T getFromCache(String cacheKey, Supplier<T> dataLoader) {
        // 从缓存获取数据
        T data = (T) redisTemplate.opsForValue().get(cacheKey);

        if (data != null) {
            return data;
        }

        // 缓存未命中,加载数据
        data = dataLoader.get();

        if (data != null) {
            // 放入缓存(永不过期)
            redisTemplate.opsForValue().set(cacheKey, data);
        }

        return data;
    }
}

本文展示了两种缓存实现方案:1) 基于ConcurrentHashMap的本地内存缓存(LocalCacheService),提供线程安全的缓存操作,包含缓存查询、自动加载、单键清除和全部清除功能;2) Redis分布式缓存(CacheService),通过RedisTemplate实现,包含基本的缓存查询和自动加载功能。两种方案均采用Supplier接口实现&quot;缓存未命中时自动加载&quot;的模式,其中本地缓存适用于单机高频访问场景,Redis缓存适用于分布式环境。代码结构清晰,展示了Sprin

相关推荐
hqxstudying19 分钟前
SpringBoot启动项目详解
java·spring boot·后端
Miraitowa_cheems40 分钟前
Redis 核心概念、命令详解与应用实践:从基础到分布式集成
数据库·redis·缓存
你我约定有三41 分钟前
分布式微服务--Nacos作为配置中心(补)关于bosststrap.yml与@RefreshScope
java·分布式·spring cloud·微服务·架构
keepDXRcuriosity2 小时前
IDEA识别lombok注解问题
java·ide·intellij-idea
酷飞飞2 小时前
C语言的复合类型、内存管理、综合案例
java·c语言·前端
宸津-代码粉碎机3 小时前
LLM 模型部署难题的技术突破:从轻量化到分布式推理的全栈解决方案
java·大数据·人工智能·分布式·python
都叫我大帅哥3 小时前
TOGAF实战解码:六大行业案例解析与成功启示
java
都叫我大帅哥3 小时前
RabbitMQ消息确认机制:从外卖小哥到数据安全的奇幻漂流
java·rabbitmq
周航宇JoeZhou6 小时前
JP3-3-MyClub后台后端(二)
java·mysql·vue·ssm·springboot·项目·myclub
羊锦磊6 小时前
[ java 网络 ] TPC与UDP协议
java·网络·网络协议