- Gauva基于LRU算法,Caffeine基于W-TinyLFU算法(结合了LRU和LFU的特点) Caffeine支持异步加载 Caffeine性能和开销都优于Guava Caffeine的命中率更高
public class TestCaffeine { public static void main(String[] args) throws Exception { // 1、手动加载 Cache<String, String> cache = Caffeine.newBuilder() .expireAfterWrite(10, TimeUnit.MINUTES) .maximumSize(10) .build(); cache.put("key1", "test1"); System.out.println("手动加载:" + cache.getIfPresent("key1")); System.out.println("---"); // 2、LoadingCache自动加载 LoadingCache<String, String> cache1 = Caffeine.newBuilder() .expireAfterWrite(10, TimeUnit.MINUTES) .maximumSize(10) .build(new CacheLoader<String, String>() { @Override public @Nullable String load(@NonNull String s) throws Exception { return s + "_value"; } }); System.out.println("LoadingCache自动加载:" + cache1.get("key1")); System.out.println("---"); // 3、异步手动加载 AsyncCache<String, String> cache2 = Caffeine.newBuilder() .expireAfterWrite(10, TimeUnit.MINUTES) .maximumSize(10) .buildAsync(); CompletableFuture<String> future = cache2.get("key1", key -> { return key + "_value111"; }); System.out.println("异步手动加载:" + future.get()); System.out.println("---"); // 4、异步自动加载 AsyncLoadingCache<String, String> cache3 = Caffeine.newBuilder() .expireAfterWrite(10, TimeUnit.MINUTES) .maximumSize(10) .buildAsync(new CacheLoader<String, String>() { @Override public @Nullable String load(@NonNull String s) throws Exception { return s + "_syncvalue"; } }); System.out.println("异步自动加载:" + cache3.get("key3").get()); }
标签:LRU,caffeine,Tiny,性能,开销 来源:
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。