Java LocalCache 本地缓存的实现实例
2017-05-08 15:25
871 查看
源码地址: GitHub
使用场景
在Java应用中,对于访问频率高,更新少的数据,通常的方案是将这类数据加入缓存中。相对从数据库中读取来说,读缓存效率会有很大提升。
在集群环境下,常用的分布式缓存有
Redis、
Memcached等。但在某些业务场景上,可能不需要去搭建一套复杂的分布式缓存系统,在单机环境下,通常是会希望使用内部的缓存(
LocalCache)。
实现
这里提供了两种
LocalCache的实现,一种是基于
ConcurrentHashMap实现基本本地缓存,另外一种是基于
LinkedHashMap实现
LRU策略的本地缓存。
基于ConcurrentHashMap的实现
static { timer = new Timer(); map = new ConcurrentHashMap<>(); }
以
ConcurrentHashMap作为缓存的存储结构。因为
ConcurrentHashMap的线程安全的,所以基于此实现的
LocalCache在多线程并发环境的操作是安全的。在
JDK1.8中,
ConcurrentHashMap是支持完全并发读,这对本地缓存的效率也是一种提升。通过调用
ConcurrentHashMap对
map的操作来实现对缓存的操作。
私有构造函数
private LocalCache() { }
LocalCache是工具类,通过私有构造函数强化不可实例化的能力。
缓存清除机制
/** * 清除缓存任务类 */ static class CleanWorkerTask extends TimerTask { private String key; public CleanWorkerTask(String key) { this.key = key; } public void run() { LocalCache.remove(key); } }
清理失效缓存是由
Timer类实现的。内部类
CleanWorkerTask继承于
TimerTask用户清除缓存。每当新增一个元素的时候,都会调用
timer.schedule加载清除缓存的任务。
基于LinkedHashMap的实现
以
LinkedHashMap作为缓存的存储结构。主要是通过
LinkedHashMap的按照访问顺序的特性来实现
LRU策略。
LRU
LRU是
Least Recently Used的缩写,即最近最久未使用。
LRU缓存将会利用这个算法来淘汰缓存中老的数据元素,从而优化内存空间。
基于LRU策略的map
这里利用
LinkedHashMap来实现基于
LRU策略的
map。通过调用父类
LinkedHashMap的构造函数来实例化
map。参数
accessOrder设置为
true保证其可以实现
LRU策略。
static class LRUMap<K, V> extends LinkedHashMap<K, V> { ... // 省略部分代码 public LRUMap(int initialCapacity, float loadFactor) { super(initialCapacity, loadFactor, true); } ... // 省略部分代码 /** * 重写LinkedHashMap中removeEldestEntry方法; * 新增元素的时候,会判断当前map大小是否超过DEFAULT_MAX_CAPACITY,超过则移除map中最老的节点; * * @param eldest * @return */protected boolean removeEldestEntry(Map.Entry<K, V> eldest) { return size() > DEFAULT_MAX_CAPACITY; } }
线程安全
/** * 读写锁 */ private final ReadWriteLock readWriteLock = new ReentrantReadWriteLock(); private final Lock rLock = readWriteLock.readLock(); private final Lock wLock = readWriteLock.writeLock();
LinkedHashMap并不是线程安全,如果不加控制的在多线程环境下使用的话,会有问题。所以在
LRUMap中引入了
ReentrantReadWriteLock读写锁,来控制并发问题。
缓存淘汰机制
protected boolean removeEldestEntry(Map.Entry<K, V> eldest) { return size() > DEFAULT_MAX_CAPACITY; }
此处重写
LinkedHashMap中
removeEldestEntry方法, 当缓存新增元素的时候,会判断当前map大小是否超过
DEFAULT_MAX_CAPACITY,超过则移除map中最老的节点。
缓存清除机制
缓存清除机制与
ConcurrentHashMap的实现一致,均是通过
timer实现。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- Java中LocalCache本地缓存实现代码
- JS实现本地缓存实例
- Java 本地缓存的实现(转)
- Java实现纪元秒和本地日期时间互换的方法【经典实例】
- Java8简单的本地缓存实现
- Android Studio中实现本地html中js与java交互简单实例
- Java中读写锁的实现及使用读写锁简单实现缓存系统的实例
- java实现本地缓存
- Java本地缓存的实现代码
- JAVA编程——简单本地缓存的实现
- java java local cache本地缓存的两种实现,一个基于list轮询一个基于timer定时
- java java local cache本地缓存的两种实现,一个基于list轮询一个基于timer定时
- Java 实现本地缓存工具
- Java学习之ConcurrentHashMap实现一个本地缓存
- java中读写锁的实现及使用读写锁简单实现缓存系统的实例
- java对象本地缓存机制的实现
- C#实现可缓存网页到本地的反向代理工具实例
- Java8简单的本地缓存实现
- Java实现LRU缓存的实例详解
- 如何使用Java实现简单的本地缓存?