背景
项目中需要使用到很多个DataSource,就想着用一个LRU的算法来进行缓存。刚开始自己用LinkedHashMap,synchronized关键字实现了一个LRU的缓存类。但是被老大鄙视了,说还是google大法好,而且效率肯定也比我的高。好吧,所以就去学习了一个guava Cache的使用。
本篇文章主要是参考的是官方文档,有兴趣的同学可以自行去阅读。
Guava Cache简介
Guava Cache底层就是用的ConcurrentHashMap来实现的。主要区别在于ConcurrentHashMap会一直保存所有添加的元素,直到显式地移除。而Guava Cache为了限制内存的使用,通常都是设定为自动回收元素。而自动回收元素的规则就为LRU算法。同时,Guavav Cache实现了缓存的自动加载,非常方便。
新建一个Guava Cache
Guava API中提供了CacheBuilder来初始化一个cache。通常有两种实现方式:
private static final Cache<String,String> caches = CacheBuilder
.newBuilder()