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

  1. 1、本文档共2页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
10行Java代码实现最近被使用(LRU)缓存.doc

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

文档评论(0)

dmz158 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档