博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
10 行 Java 代码实现 LRU 缓存
阅读量:5279 次
发布时间:2019-06-14

本文共 916 字,大约阅读时间需要 3 分钟。

10 行 Java 代码实现 LRU 缓存 (整理自网络)

最近最少使用缓存的回收

为了实现缓存回收,我们需要很容易做到:

  • 查询出最近最晚使用的项
  • 给最近最少使用的项做一个标记

链表可以实现这两个操作。检测使用最近最少使用的项只需要返回链表的尾部。标记一项为最近最少使用的项只需要从当前位置移除而后将该项放置到链表头部。比较困难的事情是怎么快速的在链表中找到该项。

哈希表的帮助

看一下我们工具箱中的数据结构,哈希表可以在(消耗)常量的时间内索引到某个对象。如果我们创建一个形如 key -> 链表节点 的哈希表,我们就能在常量时间内找到最近使用的节点。更甚的是,我们也能够在常量时间内判断节点是否存在。找到这个节点后,我们就能将这个节点移动到链表的最前端了,标记为最近使用的项。

Java 捷径

很少有一种编程语言的标准库中有通用的数据结构能提供上述功能的。这是一种混合的数据结构,我们需要在哈希表的基础上建立一个链表。但是 Java 已经为我们提供了这种形式的数据结构LinkedHashMap,它甚至提供可覆盖回收策略的方法 。唯一需要我们注意的事情是,该链表的顺序是插入的顺序,而不是访问的顺序。但是,有一个提供了一个选项,可以使用访问顺序。

代码示例:

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;    }}

示例完毕。

转载于:https://www.cnblogs.com/flotang/p/9962111.html

你可能感兴趣的文章
普通求素数和线性筛素数
查看>>
PHP截取中英文混合字符
查看>>
电子眼抓拍大解密
查看>>
51nod1076 (边双连通)
查看>>
Linux pipe函数
查看>>
Zerver是一个C#开发的Nginx+PHP+Mysql+memcached+redis绿色集成开发环境
查看>>
程序的静态链接,动态链接和装载 (补充)
查看>>
关于本博客说明
查看>>
[Kaggle] Sentiment Analysis on Movie Reviews
查看>>
价值观
查看>>
mongodb命令----批量更改文档字段名
查看>>
国外常见互联网盈利创新模式
查看>>
android:scaleType属性
查看>>
shell脚本
查看>>
Upload Image to .NET Core 2.1 API
查看>>
【雷电】源代码分析(二)-- 进入游戏攻击
查看>>
Linux中防火墙centos
查看>>
centos下同时启动多个tomcat
查看>>
Leetcode Balanced Binary Tree
查看>>
[JS]递归对象或数组
查看>>