「Java框架」java真正的缓存之王,效率直接上来了

介绍语

本号主要是Java常用关键技术点,通用工具类的分享;以及springboot+springcloud+Mybatisplus+druid+mysql+redis+swagger+maven+docker等集成框架的技术分享;datax、kafka、flink等大数据处理框架的技术分享。文章会不断更新,欢迎码友关注点赞收藏转发!

望各位码友点击关注,冲1000粉。后面会录制一些视频教程,图文和视频结合,比如:图书介绍网站系统、抢购系统、大数据中台系统等。技术才是程序猿的最爱,码友们冲啊

如果码友觉得代码太长,可以从头到尾快速扫射一遍,了解大概即可。觉得有用后再转发收藏,以备不时之需。

正文:

Caffeine Cache,它是站在巨人的肩膀上-Guava Cache,借着他的思想优化了算法发展而来。当前最强本地缓存框架,不接受反驳( ̄▽ ̄)"

Caffeine Cache 的github地址:

https://github.com/ben-manes/caffeine

Caffeine 的底层算法很牛比,我自己也不清楚解释不好,就不献丑了,它有各种加载策略,回收策略,可以自动刷新缓存等,功能及其强大,我只会皮毛,下面直接来一个例子

 
import com.github.benmanes.caffeine.cache.Cache;
 import com.github.benmanes.caffeine.cache.Caffeine;
 import com.github.benmanes.caffeine.cache.LoadingCache;
 ​
 import java.util.ArrayList;
 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
 import java.util.concurrent.TimeUnit;
 ​
 /**
  * @author java老牛
  */
 public class CaffineCache {
 ​
     public static void main(String[] args) {
         List<Map<String, Object>> javaList = new ArrayList<>();
         javaList.add(new HashMap<String, Object>(3) {{
             put("java-ccc", "abcd");
             put("java-aaa", "求三联");
             put("java-bbb", 123);
         }});
         CaffineCache.putListByClassify("java", javaList);
 ​
         List<Map<String, Object>> netList = new ArrayList<>();
         netList.add(new HashMap<String, Object>(3) {{
             put("net-ccc", "abcd");
             put("net-aaa", "求三联");
             put("net-bbb", 123);
         }});
         CaffineCache.putListByClassify("net", netList);
 ​
         List<Map<String, Object>> phpList = new ArrayList<>();
         phpList.add(new HashMap<String, Object>(3) {{
             put("php-ccc", "abcd");
             put("php-aaa", "求三联");
             put("php-bbb", 123);
         }});
         CaffineCache.putListByClassify("php", phpList);
 ​
         System.out.println("net list:");
         System.out.println(CaffineCache.getListByClassify("net"));
 ​
         System.out.println("java List");
         System.out.println(refreshCache.get("java"));
 ​
     }
 ​
     // 手动创建缓存
     private static final Cache<String, List<Map<String, Object>>> ARTICLE_LIST_CACHE = Caffeine.newBuilder()
         // 12小时缓存过期
         .expireAfterWrite(12, TimeUnit.HOURS)
         // 最大缓存个数
         .maximumSize(1000)
         .build();
 ​
     // 取缓存
     public static List<Map<String, Object>> getListByClassify(String key) {
         return ARTICLE_LIST_CACHE.getIfPresent(key);
     }
 ​
     // 存缓存
     public static void putListByClassify(String key, List<Map<String, Object>> value) {
         ARTICLE_LIST_CACHE.put(key, value);
     }
 ​
     private static final LoadingCache<String, List<Map<String, Object>>> refreshCache = Caffeine.newBuilder()
         // 最大缓存数
         .maximumSize(10_000)
         // 每分钟刷新一次
         .refreshAfterWrite(1, TimeUnit.MINUTES)
         .build(CaffineCache::loadCache);
 ​
     private static List<Map<String, Object>> loadCache(String key) {
         // 这里自动加载数据库数据到缓存,我这里直接写死咯
         List<Map<String, Object>> javaList = new ArrayList<>();
         javaList.add(new HashMap<String, Object>(3) {{
             put("java-ccc", "abcd");
             put("java-aaa", "求三联");
             put("java-bbb", 123);
         }});
         return javaList;
     }
 ​
 }

结果打印

 

maven依赖包:

 <dependency>
     <groupId>com.github.ben-manes.caffeine</groupId>
     <artifactId>caffeine</artifactId>
     <version>2.6.2</version>
 </dependency>

鄙人编码十年多,在项目中也积累了一些工具类,很多工具类在每个项目都有在用,很实用。大部分是鄙人封装的,有些工具类是同事封装的,有些工具类已经不记得是ctrl+c的还是自己封装的了,现在有空就会总结项目中大部分的工具类,分享给各位码友。如果文章中涉及的代码有侵权行为请通知鄙人处理。

计划是先把工具类整理出来,正所谓工欲善其事,必先利其器。项目中不管是普通单体项目还是多模块maven项目或是分布式微服务,一部分功能模块都是可以重用的,工具类模块就是其中之一。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员阿宁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值