10行Java代码实现最近被使用(LRU)缓存

上传人:宝路 文档编号:23233692 上传时间:2017-11-30 格式:DOC 页数:2 大小:70.51KB
返回 下载 相关 举报
10行Java代码实现最近被使用(LRU)缓存_第1页
第1页 / 共2页
10行Java代码实现最近被使用(LRU)缓存_第2页
第2页 / 共2页
亲,该文档总共2页,全部预览完了,如果喜欢就下载吧!
资源描述

《10行Java代码实现最近被使用(LRU)缓存》由会员分享,可在线阅读,更多相关《10行Java代码实现最近被使用(LRU)缓存(2页珍藏版)》请在金锄头文库上搜索。

1、http:/ 行 Java 代码实现最近被使用(LRU)缓存在最近的面试中,我曾被多次问到,怎么实现一个最近最少使用(LRU)的缓存。缓存可以通过哈希表来实现,然而为这个缓存增加大小限制会变成另一个有意思的问题。现在我们看一下怎么实现。最近最少使用缓存的回收为了实现缓存回收,我们需要很容易做到:查询出最近最晚使用的项 给最近使用的项做一个标记 链表可以实现这两个操作。检测最近最少使用的项只需要返回链表的尾部。标记一项为最近使用的项只需要从当前位置移除,然后将该项放置到头部。比较困难的事情是怎么快速的在链表中找到该项。哈希表的帮助看一下我们工具箱中的数据结构,哈希表可以在(消耗)常量的时间内索引

2、到某个对象。如果我们创建一个形如 key-链表节点的哈希表,我们就能够在常量时间内找到最近使用的节点。更甚的是,我们也能够在常量时间内判断节点的是否存在(或不存在) ;找到这个节点后,我们就能将这个节点移动到链表的最前端,标记为最近使用的项了。http:/ 的捷径据我所知,很少有一种编程语言的标准库中有通用的数据结构能提供上述功能的。这是一种混合的数据结构,我们需要在哈希表的基础上建立一个链表。但是 Java 已经为我们提供了这种形式的数据结构-LinkedHashMap!它甚至提供可覆盖回收策略的方法。唯一需要我们注意的事情是,改链表的顺序是插入的顺序,而不是访问的顺序。但是,有一个构造函数

3、提供了一个选项,可以使用访问的顺序。无需多说: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;

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号