hutool系列教材 (十七)- 常用类辅助工具 - Java 缓存工具

步骤1:先运行,看到效果,再学习
步骤2:模仿和排错
步骤3:TestCache

步骤 1 : 先运行,看到效果,再学习

老规矩,先下载下载区(点击进入)的可运行项目,配置运行起来,确认可用之后,再学习做了哪些步骤以达到这样的效果。
运行 TestCache

先运行,看到效果,再学习

步骤 2 : 模仿和排错

在确保可运行项目能够正确无误地运行之后,再严格照着教程的步骤,对代码模仿一遍。
模仿过程难免代码有出入,导致无法得到期望的运行结果,此时此刻通过比较正确答案 ( 可运行项目 ) 和自己的代码,来定位问题所在。
采用这种方式,学习有效果,排错有效率,可以较为明显地提升学习速度,跨过学习路上的各个槛。

推荐使用diffmerge软件,进行文件夹比较。把你自己做的项目文件夹,和我的可运行项目文件夹进行比较。
这个软件很牛逼的,可以知道文件夹里哪两个文件不对,并且很明显地标记出来
这里提供了绿色安装和使用教程:diffmerge 下载和使用教程

步骤 3 : TestCache

package cn.how2j.test;

import static java.lang.annotation.ElementType.METHOD;

import static java.lang.annotation.ElementType.TYPE;

import java.lang.annotation.Documented;

import java.lang.annotation.Inherited;

import java.lang.annotation.Retention;

import java.lang.annotation.RetentionPolicy;

import java.lang.annotation.Target;

import java.lang.reflect.Method;

import org.junit.Test;

import cn.hutool.cache.Cache;

import cn.hutool.cache.CacheUtil;

import cn.hutool.cache.file.LFUFileCache;

import cn.hutool.core.collection.CollectionUtil;

import cn.hutool.core.convert.Convert;

import cn.hutool.core.thread.ThreadUtil;

import cn.hutool.core.util.ReflectUtil;

import cn.hutool.core.util.StrUtil;

public class TestCache {

    @Test

    @Comment("缓存工具")

    public void test0(){

        p4("hutool的缓存,在处理缓存满了或者到期的时候,有如下几种策略:");

        p3("FIFOCache","first in first out , 先入先出,一旦缓存满了,先放进去的,先被清空");

        p3("LFUCache","least frequently used, 一旦缓存满了,用得最少的,先被清空 (命中低的数据被清空)");

        p3("LRUCache","least recently used, 一旦缓存满了,最久没用的,先被清空 (旧数据被清空)");

        p3("TimedCache","一旦时间到了,被清空 (考虑时效性)");

        p3("WeakCache","一旦内存满了,要垃圾回收了,优先被清空 (内存占用重要性)");

        p3("FileCach","把文件对象作为缓存,减少IO访问频率");

         

//      LFUCache

//      LRUCache least recently used

//      TimedCache

//      WeakCache

//      FileCach

    }

     

    @Test

    @Comment("FIFO 示例")

    public void test1(){

        p4("初始化缓存大小是 2");

        p4("接着向里面挨个放入1,2,3,导致缓存变满");

        Cache<String,Integer> cache= CacheUtil.newFIFOCache(2);

        cache.put("key1",1 );

        cache.put("key2",2 );

        cache.put("key3",3 );

        p3("遍历缓存中的数据",CollectionUtil.join(cache, ","));

        p4("如预料一般,最早放入的最先被清空");

    }

     

    @Test

    @Comment("LFUCache 示例")

    public void test2(){

        p4("初始化缓存大小是 2");

        p4("接着向里面挨个放入1,2,3,导致缓存变满");

        Cache<String,Integer> cache= CacheUtil.newLFUCache(2);

        cache.put("key1",1 );

        cache.put("key2",2 );

        p4("中途故意使用一次 key1");

        cache.get("key1");

        cache.put("key3",3 );

        p3("遍历缓存中的数据",CollectionUtil.join(cache, ","));

        p4("如预料一般,使用频率最低的 2 的被清空");

    }

    @Test

    @Comment("LFUCache 示例")

    public void test3(){

        p4("初始化缓存大小是 2");

        p4("接着向里面挨个放入1,2,3,导致缓存变满");

        Cache<String,Integer> cache= CacheUtil.newLRUCache(2);

        cache.put("key1",1 );

        cache.put("key2",2 );

        p4("中途故意使用一次 key1");

        cache.get("key1");

        cache.put("key3",3 );

        p3("遍历缓存中的数据",CollectionUtil.join(cache, ","));

        p4("如预料一般,最久没有被使用的  2 的被清空");

    }

    @Test

    @Comment("TimedCache 示例")

    public void test4(){

        p4("初始化缓存大小是 2");

        p4("接着向里面挨个放入1,2, 分别放设置存放时间为1秒和5秒");

        Cache<String,Integer> cache= CacheUtil.newTimedCache(Integer.MAX_VALUE);

        cache.put("key1",11000 );

        cache.put("key2",2,5000 );

        p4("休息3秒");

        ThreadUtil.sleep(3000);

        p3("遍历缓存中的数据",CollectionUtil.join(cache, ","));

        p4("如预料一般, 经过3秒后,1被清空了,2还在");

    }

     

    @Test

    @Comment("WeakCache 示例")

    public void test5(){

        p4("WeekCache表示当垃圾回收发生的时候,不会阻挡回收器把它回收走。");

         

        p4("请注意看描述:\"不会阻挡\", 就是说,垃圾回收真正要对它下手了,是可以下手的。");

        p4("但是垃圾回收发生的时候,不一定会回收所有垃圾和 week引用。");

        p4("正因为如此,不易观察到现象,而且不稳定,所以就不做演示了,免得误导");

         

    }

     

    @Test

    @Comment("FileCache 示例")

    public void test6(){

        p4("FileCache 也分 LFU, LRU 等,只是调用方式有所区别,并没有被放到 CacheUtil里,找了好一会儿才找到。。。,");

        //参数1:容量,能容纳的byte数

        //参数2:最大文件大小,byte数,决定能缓存至少多少文件,大于这个值不被缓存直接读取

        //参数3:超时。毫秒

         

        long capacity = 1024*1024*500//最多500m, 太大了,内存吃不消,缓存就没法实施了

        long maxFileSize = 1024*1024*10//最大10m, 文件小于这个就缓存,太大了也不缓存

        long timeout = 1000*60*60*24//缓存一天,超过这个就自动从缓存里移除了

         

        LFUFileCache cache = new LFUFileCache(1024*1024*5005002000);

        //使用办法:

        //byte[] bytes = cache.getFileBytes("e:/project/hutool/img/logo.png");

         

    }

     

    private String preComment = null;

    private void c(String msg) {

        System.out.printf("\t备注:%s%n", msg);

    }

    private void p1(String type1, Object value1, String type2, Object value2) {

        p(type1, value1, type2, value2, "format1");

    }

    private void p2(String type1, Object value1, String type2, Object value2) {

        p(type1, value1, type2, value2, "format2");

    }

    private void p3(String type1, Object value1) {

        p(type1, value1, """""format3");

    }

    private void p4(Object value) {

        p(null, value, """""format4");

    }

    private void p(String type1, Object value1, String type2, Object value2, String format) {

        try {

            throw new Exception();

        catch (Exception e) {

            String methodName = getTestMethodName(e.getStackTrace());

            Method m = ReflectUtil.getMethod(this.getClass(), methodName);

            Comment annotation = m.getAnnotation(Comment.class);

            if (null != annotation) {

                String comment = annotation.value();

                if (!comment.equals(preComment)) {

                    System.out.printf("%n%s 例子: %n%n", comment);

                    preComment = comment;

                }

            }

        }

        int padLength = 12;

        type1 = StrUtil.padEnd(type1, padLength, Convert.toSBC(" ").charAt(0));

        type2 = StrUtil.padEnd(type2, padLength, Convert.toSBC(" ").charAt(0));

        if ("format1".equals(format)) {

            System.out.printf("\t%s的:\t\"%s\" %n\t被转换为----->%n\t%s的 :\t\"%s\" %n%n", type1, value1, type2, value2);

        }

        if ("format2".equals(format)) {

            System.out.printf("\t基于 %s:\t\"%s\" %n\t获取 %s:\t\"%s\"%n%n", type1, value1, type2, value2);

        }

        if ("format3".equals(format)) {

            System.out.printf("\t%s:\t\"%s\" %n\t%n", type1, value1);

        }

        if ("format4".equals(format)) {

            System.out.printf("\t%s%n%n", value1);

             

        }

    }

    private String getTestMethodName(StackTraceElement[] stackTrace) {

        for (StackTraceElement se : stackTrace) {

            String methodName = se.getMethodName();

            if (methodName.startsWith("test"))

                return methodName;

        }

        return null;

    }

    @Target({ METHOD, TYPE })

    @Retention(RetentionPolicy.RUNTIME)

    @Inherited

    @Documented

    public @interface Comment {

        String value();

    }

}


更多内容,点击了解: https://how2j.cn/k/hutool/hutool-cache/1979.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JedisUtil是一个Java Redis缓存工具,它封装了Jedis客户端的基本操作,使得使用Redis缓存更加简单方便。 以下是JedisUtil的示例代码: ``` import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; public class JedisUtil { private static JedisPool jedisPool; static { JedisPoolConfig jedisPoolConfig = new JedisPoolConfig(); jedisPoolConfig.setMaxTotal(1000); jedisPoolConfig.setMaxIdle(100); jedisPool = new JedisPool(jedisPoolConfig, "localhost", 6379); } public static void set(String key, String value) { try (Jedis jedis = jedisPool.getResource()) { jedis.set(key, value); } } public static String get(String key) { try (Jedis jedis = jedisPool.getResource()) { return jedis.get(key); } } public static void del(String key) { try (Jedis jedis = jedisPool.getResource()) { jedis.del(key); } } public static void expire(String key, int seconds) { try (Jedis jedis = jedisPool.getResource()) { jedis.expire(key, seconds); } } public static boolean exists(String key) { try (Jedis jedis = jedisPool.getResource()) { return jedis.exists(key); } } } ``` 在上面的代码中,我们使用了JedisPool来管理Jedis连接,它的作用是维护一定数量的Jedis连接,以便在需要时从池中获取连接,减少了创建和关闭连接的开销。 在使用JedisUtil时,我们只需要调用set、get、del、expire和exists等方法,就可以完成对Redis缓存的操作。 例如,要将一个键值对("name", "Tom")存入Redis中,可以使用以下代码: ``` JedisUtil.set("name", "Tom"); ``` 要获取键为"name"的值,可以使用以下代码: ``` String name = JedisUtil.get("name"); ``` 同时,JedisUtil还提供了删除、设置过期时间和判断键是否存在等方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值