当前位置:首页 > Java

java如何缓存数据

2026-03-04 00:27:52Java

Java 缓存数据的常见方法

使用 HashMap 实现简单缓存

import java.util.HashMap;
import java.util.Map;

public class SimpleCache<K, V> {
    private final Map<K, V> cache = new HashMap<>();

    public void put(K key, V value) {
        cache.put(key, value);
    }

    public V get(K key) {
        return cache.get(key);
    }

    public void remove(K key) {
        cache.remove(key);
    }
}

使用 Guava Cache

Guava Cache 提供了更强大的缓存功能,包括过期策略和缓存大小限制。

import com.google.common.cache.Cache;
import com.google.common.cache.CacheBuilder;

public class GuavaCacheExample {
    private static final Cache<String, String> cache = CacheBuilder.newBuilder()
            .maximumSize(100) // 最大缓存条目数
            .expireAfterWrite(10, TimeUnit.MINUTES) // 写入后10分钟过期
            .build();

    public static void put(String key, String value) {
        cache.put(key, value);
    }

    public static String get(String key) {
        return cache.getIfPresent(key);
    }
}

使用 Caffeine Cache

Caffeine 是一个高性能的 Java 缓存库,功能比 Guava Cache 更强大。

import com.github.benmanes.caffeine.cache.Cache;
import com.github.benmanes.caffeine.cache.Caffeine;

public class CaffeineCacheExample {
    private static final Cache<String, String> cache = Caffeine.newBuilder()
            .maximumSize(100)
            .expireAfterWrite(10, TimeUnit.MINUTES)
            .build();

    public static void put(String key, String value) {
        cache.put(key, value);
    }

    public static String get(String key) {
        return cache.getIfPresent(key);
    }
}

使用 Ehcache

Ehcache 是一个广泛使用的开源 Java 缓存框架。

import org.ehcache.Cache;
import org.ehcache.CacheManager;
import org.ehcache.config.builders.CacheConfigurationBuilder;
import org.ehcache.config.builders.CacheManagerBuilder;
import org.ehcache.config.builders.ResourcePoolsBuilder;

public class EhcacheExample {
    private static CacheManager cacheManager;
    private static Cache<String, String> cache;

    static {
        cacheManager = CacheManagerBuilder.newCacheManagerBuilder().build();
        cacheManager.init();

        cache = cacheManager.createCache("myCache",
                CacheConfigurationBuilder.newCacheConfigurationBuilder(
                        String.class, String.class,
                        ResourcePoolsBuilder.heap(100)));
    }

    public static void put(String key, String value) {
        cache.put(key, value);
    }

    public static String get(String key) {
        return cache.get(key);
    }
}

使用 Spring Cache 注解

Spring 框架提供了缓存抽象,可以通过注解方式轻松实现缓存。

import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;

@Service
public class BookService {
    @Cacheable("books")
    public Book getBookByIsbn(String isbn) {
        // 这个方法只有在缓存中没有对应数据时才会执行
        return findBookInSlowSource(isbn);
    }

    private Book findBookInSlowSource(String isbn) {
        // 模拟耗时操作
        return new Book(isbn, "Some book");
    }
}

使用 Redis 作为分布式缓存

对于分布式系统,可以使用 Redis 作为缓存解决方案。

java如何缓存数据

import redis.clients.jedis.Jedis;

public class RedisCacheExample {
    private static final String REDIS_HOST = "localhost";
    private static final int REDIS_PORT = 6379;

    public static void set(String key, String value) {
        try (Jedis jedis = new Jedis(REDIS_HOST, REDIS_PORT)) {
            jedis.set(key, value);
        }
    }

    public static String get(String key) {
        try (Jedis jedis = new Jedis(REDIS_HOST, REDIS_PORT)) {
            return jedis.get(key);
        }
    }
}

缓存策略考虑因素

  • 缓存大小:设置合理的缓存大小限制
  • 过期策略:基于时间或基于访问频率
  • 淘汰策略:LRU、LFU 等
  • 持久化:是否需要将缓存数据持久化到磁盘
  • 线程安全:确保缓存在多线程环境下的安全性

标签: 缓存数据
分享给朋友:

相关文章

vue实现数据互通

vue实现数据互通

Vue 实现数据互通的方法 Vue 提供了多种方式实现组件间的数据互通,以下是几种常见的方法: 父子组件通信 Props 传递数据 父组件通过 props 向子组件传递数据。 <!-- 父组…

vue怎么实现数据

vue怎么实现数据

Vue 数据实现方式 Vue 提供了多种方式来实现数据的响应式绑定和管理,核心是通过数据驱动视图的更新。 响应式数据声明 在 Vue 组件中,可以通过 data 选项声明响应式数据。这些数据会被 V…

vue实现数据更改

vue实现数据更改

Vue 数据更改的实现方法 Vue 提供了多种方式来响应式地更改数据,以下是几种常见的方法: 直接修改数据属性 在 Vue 实例中,可以直接修改 data 对象的属性,Vue 会自动检测这些变化并更…

vue实现数据太多

vue实现数据太多

处理 Vue 中大数据量的优化方案 虚拟滚动(Virtual Scrolling) 使用 vue-virtual-scroller 或 vxe-table 等库实现虚拟滚动,仅渲染可视区域内的 DOM…

vue实现数据监听

vue实现数据监听

Vue 数据监听实现方式 Vue 提供了多种方式实现数据监听,核心机制基于响应式系统。以下是常见方法: 响应式属性(data 和 computed) 在组件选项中定义 data 返回对象,Vue 会…

vue实现数据拼接

vue实现数据拼接

Vue 实现数据拼接的方法 在 Vue 中实现数据拼接可以通过多种方式完成,以下是一些常见的方法: 使用计算属性(Computed Properties) 计算属性是 Vue 中处理数据拼接的理想选…