首页 > 编程语言 >Java中的灵活缓存失效策略设计:从TTL到LRU的实现

Java中的灵活缓存失效策略设计:从TTL到LRU的实现

时间:2024-08-10 20:28:12浏览次数:18  
标签:缓存 Java cache System LRU TTL println out

Java中的灵活缓存失效策略设计:从TTL到LRU的实现

大家好,我是微赚淘客系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!

缓存失效策略在现代应用程序中至关重要,它决定了缓存数据的更新和淘汰机制。本文将探讨在Java中如何实现灵活的缓存失效策略,包括TTL(Time-To-Live)和LRU(Least Recently Used)等策略。我们将通过具体代码示例展示如何在Java应用中实现这些策略。

1. TTL(Time-To-Live)缓存失效策略

TTL策略是一种基于时间的缓存失效策略,它在缓存条目达到指定的时间后自动失效。这种策略适用于需要在特定时间段内保持数据有效性的场景。

1.1 使用Guava缓存库实现TTL

Guava是Google提供的一个Java开源库,它包括了一个强大的缓存工具类Cache,可以方便地实现TTL策略。

首先,添加Guava的依赖(在pom.xml中):

<dependency>
    <groupId>com.google.guava</groupId>
    <artifactId>guava</artifactId>
    <version>31.1-jre</version>
</dependency>

以下是使用Guava实现TTL缓存的示例:

package cn.juwatech.example;

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

import java.util.concurrent.TimeUnit;

public class TTLCacheExample {
    public static void main(String[] args) throws InterruptedException {
        // 创建TTL缓存,设置条目在10秒后过期
        Cache<String, String> cache = CacheBuilder.newBuilder()
                .expireAfterWrite(10, TimeUnit.SECONDS)
                .build();

        // 添加缓存项
        cache.put("key1", "value1");

        // 获取缓存项
        System.out.println("Value for key1: " + cache.getIfPresent("key1"));

        // 等待12秒,使缓存项过期
        Thread.sleep(12000);

        // 尝试获取缓存项
        System.out.println("Value for key1 after expiration: " + cache.getIfPresent("key1"));
    }
}

2. LRU(Least Recently Used)缓存失效策略

LRU策略是一种基于访问频率的缓存失效策略,它会在缓存达到容量限制时淘汰最久未使用的条目。这种策略适用于缓存容量有限的场景。

2.1 使用Guava缓存库实现LRU

Guava的CacheBuilder还支持LRU策略,只需设置最大缓存容量即可。

以下是使用Guava实现LRU缓存的示例:

package cn.juwatech.example;

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

public class LRUCacheExample {
    public static void main(String[] args) {
        // 创建LRU缓存,设置最大容量为3
        Cache<String, String> cache = CacheBuilder.newBuilder()
                .maximumSize(3)
                .build();

        // 添加缓存项
        cache.put("key1", "value1");
        cache.put("key2", "value2");
        cache.put("key3", "value3");

        // 获取缓存项
        System.out.println("Value for key1: " + cache.getIfPresent("key1"));
        System.out.println("Value for key2: " + cache.getIfPresent("key2"));
        System.out.println("Value for key3: " + cache.getIfPresent("key3"));

        // 添加更多项,触发LRU策略
        cache.put("key4", "value4");

        // 检查缓存项
        System.out.println("Value for key1 after LRU eviction: " + cache.getIfPresent("key1")); // 可能为null
        System.out.println("Value for key2 after LRU eviction: " + cache.getIfPresent("key2")); // 可能为null
        System.out.println("Value for key3: " + cache.getIfPresent("key3"));
        System.out.println("Value for key4: " + cache.getIfPresent("key4"));
    }
}

3. 自定义缓存失效策略

除了使用现有的库,我们还可以根据需要自定义缓存失效策略。以下是一个简单的自定义LRU缓存的实现:

package cn.juwatech.example;

import java.util.LinkedHashMap;
import java.util.Map;

public class CustomLRUCache<K, V> extends LinkedHashMap<K, V> {
    private final int capacity;

    public CustomLRUCache(int capacity) {
        super(capacity, 0.75f, true); // accessOrder = true for LRU order
        this.capacity = capacity;
    }

    @Override
    protected boolean removeEldestEntry(Map.Entry<K, V> eldest) {
        return size() > capacity;
    }

    public static void main(String[] args) {
        // 创建自定义LRU缓存,设置最大容量为3
        CustomLRUCache<String, String> cache = new CustomLRUCache<>(3);

        // 添加缓存项
        cache.put("key1", "value1");
        cache.put("key2", "value2");
        cache.put("key3", "value3");

        // 获取缓存项
        System.out.println("Value for key1: " + cache.get("key1"));
        System.out.println("Value for key2: " + cache.get("key2"));
        System.out.println("Value for key3: " + cache.get("key3"));

        // 添加更多项,触发LRU策略
        cache.put("key4", "value4");

        // 检查缓存项
        System.out.println("Value for key1 after LRU eviction: " + cache.get("key1")); // 可能为null
        System.out.println("Value for key2 after LRU eviction: " + cache.get("key2")); // 可能为null
        System.out.println("Value for key3: " + cache.get("key3"));
        System.out.println("Value for key4: " + cache.get("key4"));
    }
}

总结

本文探讨了在Java中实现灵活缓存失效策略的方法,包括TTL和LRU策略。使用Guava库可以方便地实现这些策略,而自定义实现则提供了更高的灵活性和控制。选择合适的缓存失效策略对于优化应用性能和资源管理至关重要。

本文著作权归聚娃科技微赚淘客系统团队,转载请注明出处!

标签:缓存,Java,cache,System,LRU,TTL,println,out
From: https://blog.csdn.net/weixin_44409190/article/details/140879362

相关文章

  • Java中的异步编程模型与事件处理框架:从CompletableFuture到Reactive Streams
    Java中的异步编程模型与事件处理框架:从CompletableFuture到ReactiveStreams大家好,我是微赚淘客系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!在现代软件开发中,异步编程和事件驱动架构变得越来越重要。它们能有效提高应用程序的性能和响应速度,特别是在处理高并发和I......
  • 已解决:java.lang.UnsupportedClassVersionError 异常的正确解决方法,亲测有效!!!
    java.lang.UnsupportedClassVersionError是一个常见的错误,通常出现在运行一个Java程序时,提示某个类的版本与当前JVM(JavaVirtualMachine)不兼容。这通常意味着你试图在一个较低版本的JVM上运行由较高版本的Java编译器编译的类文件。本文将详细分析该错误的成因,并提供有效的解......
  • Java IO 流详解
    概述流是一个抽象的概念,代表了数据的无结构化传递。流的本质是数据在不同设备之间的传输。在Java中,数据的读取和写入都是以流的方式进行的在Java中,根据数据流向的不同,可以将流分为输入(Input)流和输出(Output)流。根据单位的不同,可以将流分为字节流和字符流。根据等级的不同,可以......
  • Java计算机毕业设计基于Android的校园网上拍卖平台(开题报告+源码+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景在数字化校园建设的浪潮中,学生们对于便捷、高效的二手商品交易需求日益增长。传统的校园跳蚤市场受限于时间、空间等因素,难以满足学生群体对于多样化......
  • Spring Boot:开启Java开发的新篇章
    引言随着互联网技术的飞速发展,业务需求变化日益频繁,对开发效率提出了更高要求。传统的Java应用构建过程往往繁琐复杂,涉及到大量的配置文件编写与依赖管理等工作。SpringBoot正是针对这一痛点而生,它通过约定优于配置的原则,简化了Spring应用的搭建过程,使得开发者可以更加专......
  • Java计算机毕业设计基于微信小程序的HPV疫苗预约与抢苗系统的设计与实现(开题+源码+论
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着健康意识的提升,人们对疾病预防的重视程度日益增强,尤其是针对女性健康的HPV(人乳头瘤病毒)疫苗,其作为预防宫颈癌等恶性肿瘤的有效手段,需求量急剧增......
  • Java计算机毕业设计基于Android的生活记账小助手APP的设计与实现(开题报告+源码+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景在快节奏的现代生活中,个人财务管理成为了许多人面临的一大挑战。随着智能手机的普及和移动互联网技术的飞速发展,移动应用成为辅助个人财务管理的得力......
  • Java计算机毕业设计基于微信小程序的网络文学管理平台(开题+源码+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着移动互联网的迅猛发展,网络文学已成为大众文化消费的重要组成部分,其便捷性、互动性和丰富性深受读者喜爱。然而,传统网络文学平台多依赖于网页或AP......
  • 暑假学习Java第六周
    这周我学习了cmd的基础语言,在Java编程语言中,"CMD"主要指的是命令行接口,它允许开发者通过命令行窗口执行各种操作系统级的任务。Java标准类库中提供了一些用于在命令行界面中执行命令的类和接口,最主要的是 Runtime 类和 ProcessBuilder 类。这些类使得从Java应用程序中启动其......
  • 如何在Java项目中使用自定义序列化器处理URL
    如何在Java项目中使用自定义序列化器处理URL在Java开发中,处理和序列化URL是一个常见的需求,尤其是在涉及到图像资源时。如果项目需要根据特定条件处理图像URL(如添加前缀),可以自定义一个序列化器来简化这一过程。本文将介绍如何创建一个自定义的ImgJsonSerializer类,处理单个URL和UR......