10 行 Java 代码实现 LRU 缓存
10 行 Java 代码实现 LRU 缓存 (整理自网络)
最近最少使用缓存的回收
为了实现缓存回收,我们需要很容易做到:
- 查询出最近最晚使用的项
- 给最近最少使用的项做一个标记
链表可以实现这两个操作。检测使用最近最少使用的项只需要返回链表的尾部。标记一项为最近最少使用的项只需要从当前位置移除而后将该项放置到链表头部。比较困难的事情是怎么快速的在链表中找到该项。
哈希表的帮助
看一下我们工具箱中的数据结构,哈希表可以在(消耗)常量的时间内索引到某个对象。如果我们创建一个形如 key -> 链表节点 的哈希表,我们就能在常量时间内找到最近使用的节点。更甚的是,我们也能够在常量时间内判断节点是否存在。找到这个节点后,我们就能将这个节点移动到链表的最前端了,标记为最近使用的项。
Java 捷径
很少有一种编程语言的标准库中有通用的数据结构能提供上述功能的。这是一种混合的数据结构,我们需要在哈希表的基础上建立一个链表。但是 Java 已经为我们提供了这种形式的数据结构LinkedHashMap,它甚至提供可覆盖回收策略的方法 removeEldestEntry。唯一需要我们注意的事情是,该链表的顺序是插入的顺序,而不是访问的顺序。但是,有一个构造函数提供了一个选项,可以使用访问顺序。
代码示例:
import java.util.LinkedHashMap;
import java.util.Map;
public LRUCache extends LinkedHashMap {
private int cacheSize;
public LRUCache(int cacheSize) {
super(16, 0.75, true);
this.cacheSize = cacheSize;
}
protected boolean removeEldestEntry(Map.Entry eldest) {
return size() >= cacheSize;
}
}
示例完毕。