在Java中如何使用LinkedHashMap实现LRU缓存_LinkedHashMap集合实践方法

LinkedHashMap通过accessOrder=true维护访问顺序,重写removeEldestEntry方法可实现LRU缓存,容量超限时自动移除最久未使用条目,适用于轻量级缓存场景。

在java中如何使用linkedhashmap实现lru缓存_linkedhashmap集合实践方法

在Java中,LinkedHashMap 是 HashMap 的一个子类,它通过维护一个双向链表来保持元素的插入顺序或访问顺序。这个特性让它非常适合用来实现 LRU(Least Recently Used,最近最少使用)缓存机制。

什么是LRU缓存?

LRU 缓存是一种淘汰策略:当缓存容量达到上限时,优先移除最久未被使用的数据。这种机制广泛应用于内存缓存、浏览器历史记录等场景。

借助 LinkedHashMap 提供的构造函数和重写方法的能力,我们可以非常简洁地实现一个高效的 LRU 缓存。

LinkedHashMap 实现 LRU 的关键参数

要让 LinkedHashMap 支持 LRU,需要使用其特定的构造函数:

立即学习“Java免费学习笔记(深入)”;

LinkedHashMap(int initialCapacity, float loadFactor, boolean accessOrder)

其中最关键的是第三个参数:

accessOrder = false:按插入顺序排序(默认) accessOrder = true:按访问顺序排序,即每次 get 或 put 已存在的 key,该条目会移到链表末尾

启用 accessOrder = true 后,最近访问的元素始终在链表尾部,最久未访问的在头部 —— 这正是 LRU 所需的行为。

重写 removeEldestEntry 方法控制容量

LinkedHashMap 提供了一个可重写的方法:

网易人工智能 网易人工智能

网易数帆多媒体智能生产力平台

网易人工智能 206 查看详情 网易人工智能

protected boolean removeEldestEntry(Map.Entry eldest)

该方法决定是否移除最老的条目(链表头部)。我们可以通过重写它来实现自动清理:

返回 true:移除最老条目 返回 false:保留

例如,限制缓存最多存放 3 个元素:

@Overrideprotected boolean removeEldestEntry(Map.Entry eldest) {    return size() > 3;}

完整代码示例:自定义 LRU 缓存

下面是一个基于 LinkedHashMap 实现的简单 LRU 缓存:

import java.util.LinkedHashMap;import java.util.Map;public class LRUCache extends LinkedHashMap {    private static final int MAX_CACHE_SIZE = 3;    public LRUCache() {        // initialCapacity=4, loadFactor=0.75, accessOrder=true        super(MAX_CACHE_SIZE + 1, 0.75f, true);    }    @Override    protected boolean removeEldestEntry(Map.Entry eldest) {        return size() > MAX_CACHE_SIZE;    }}

测试用法:

LRUCache cache = new LRUCache();cache.put("A", 1);cache.put("B", 2);cache.put("C", 3);System.out.println(cache.keySet()); // [A, B, C]cache.get("A"); // 访问 Acache.put("D", 4); // 超出容量,应淘汰 B(最久未使用)System.out.println(cache.keySet()); // [C, A, D]

输出结果会显示:
[A, B, C]
[C, A, D]

可以看到,放入 D 时触发淘汰机制,B 被移除,因为 C 和 A 更近被访问过(A 因 get 操作被移到末尾),而 B 是最久未使用的。

注意事项与优化建议

初始容量设置:建议设为最大容量 +1,避免频繁扩容 线程安全问题:LinkedHashMap 本身非线程安全,多线程环境下需额外同步处理,如使用 Collections.synchronizedMap 包装 性能考量:适用于中小规模缓存;大规模或复杂场景建议使用 ConcurrentHashMap 配合定时任务或引用队列等方式 扩展功能:可加入超时失效、命中统计等功能,在 get/put 中添加逻辑即可

基本上就这些。利用 LinkedHashMap 的访问顺序和 removeEldestEntry 机制,几行代码就能构建一个高效可靠的 LRU 缓存,适合大多数轻量级应用场景。不复杂但容易忽略细节,比如 accessOrder 必须设为 true,否则无法正确追踪访问顺序。

以上就是在Java中如何使用LinkedHashMap实现LRU缓存_LinkedHashMap集合实践方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1106844.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 18:25:45
下一篇 2025年12月2日 18:26:07

相关推荐

  • 在Linux系统上安装和配置PHPCMS的步骤

    部署%ignore_a_1%在linux系统上的核心步骤包括:1.安装php及必要扩展,如php-fpm、php-mysql等;2.配置mariadb或mysql数据库,设置root密码并创建专用数据库和用户;3.下载phpcms并解压至web服务器目录,调整文件权限以确保web服务器用户可写;4.…

    2025年12月10日
    000
  • 使用 mPDF 自定义 PDF 文件下载名称

    本文将指导你如何在使用 mPDF 库生成 PDF 文件时,自定义下载的文件名。通过修改 Output() 方法的第一个参数,你可以根据用户姓名、日期或其他变量动态生成文件名,从而提供更友好的用户体验。 在使用 mPDF 生成 PDF 文件并提供下载时,默认的文件名可能不够直观,无法有效区分不同的用户…

    2025年12月10日
    000
  • PHP怎样实现数据导出?Excel导出优化方案

    php实现数据导出最常见形式是使用phpspreadsheet库导出为excel文件,1. 推荐使用phpspreadsheet替代phpexcel,通过composer安装;2. 导出流程包括查询数据、创建excel对象、填充内容、设置输出头并输出;3. 大数据量下应分批次查询、使用迭代器、关闭缓…

    2025年12月10日 好文分享
    000
  • CSV数据导入导出怎么做?PHP处理表格数据教程

    php 处理 csv 数据高效且实用。导出步骤包括设置响应头、使用 fputcsv 输出数据、添加 bom 解决编码问题;导入则通过 fgetcsv 读取并清洗数据后插入数据库;常见问题如乱码加 bom、字段含逗号用引号包裹、大数据量分批处理、表头不固定动态读取或规范模板。 CSV 文件因为结构简单…

    2025年12月10日
    000
  • 解决PHPCMS数据库迁移后网站无法访问的问题

    phpcms迁移后网站无法访问,核心解决方法是检查数据库连接配置并清除缓存。1. 检查 config.inc.php 文件中的 db_host、db_user、db_pwd、db_name、db_pre 和 db_port 参数是否匹配新服务器环境;2. 清除 caches 目录下的所有缓存文件(包…

    2025年12月10日 好文分享
    000
  • 解决 Drupal 9 SQLite 数据库 “attempt to write a readonly database” 错误

    本文旨在帮助开发者解决 Drupal 9 项目在使用 SQLite 数据库时遇到的 “attempt to write a readonly database” 错误。该错误通常是由于文件/文件夹权限或 SELinux 强制执行策略引起的。本文将详细介绍如何诊断和解决此类问题…

    2025年12月10日
    000
  • 表单验证怎么做?防止恶意输入处理方法

    表单验证和防止恶意输入的核心在于前端负责用户体验、后端负责数据安全。具体措施包括:1. 前端验证提升用户体验,采用html5内置属性和javascript进行即时反馈;2. 后端验证确保数据安全,必须对数据类型、格式、长度、空值及业务逻辑严格校验;3. 数据清洗防止xss攻击,需进行html实体编码…

    2025年12月10日 好文分享
    000
  • 博客系统怎么开发?PHP+MySQL实战

    开发博客系统数据库设计需清晰可扩展,核心包括users、posts、comments、categories四张表。users表存储用户信息如id、username、password等;posts表记录文章详情,关联users和categories;comments表管理评论,与posts和users…

    2025年12月10日 好文分享
    000
  • 使用 mPDF 自定义 PDF 下载文件名

    本文档旨在指导开发者在使用 mPDF 库生成 PDF 文件并提供下载时,如何自定义下载的文件名。通过示例代码和详细说明,帮助开发者根据需求动态设置 PDF 文件名,例如使用用户名或其他相关信息。 自定义 PDF 文件名的方法 在使用 mPDF 生成 PDF 文件时,$mpdf->Output(…

    2025年12月10日
    000
  • 处理PHPCMS安装时文件权限不足的情况

    phpcms无法写入文件通常是因为服务器配置不当,解决方法是调整目录权限。首先确定web服务器用户(如apache的www-data或nginx的nginx),通过修改phpcms安装目录及其子目录的所有者为该用户,并使用chmod设置755权限,对特殊目录如cache、uploadfile可单独设…

    2025年12月10日 好文分享
    000
  • Windows系统下PHPCMS的安装与环境搭建

    安装phpcms需先搭建集成环境,再部署文件、创建数据库并运行安装向导。1.选择xampp等集成环境,安装php 5.6左右版本以确保兼容性;2.将phpcms解压后复制至htdocs目录并改名;3.通过phpmyadmin创建utf8字符集数据库;4.访问本地地址进入安装向导,完成许可协议、环境检…

    2025年12月10日 好文分享
    000
  • 在PHPCMS编辑器中添加自定义字体的方法

    在phpcms编辑器中添加自定义字体的方法包括:1. 找到ckeditor使用的css文件路径如statics/js/ckeditor/skins/kama/editor_content.css;2. 上传字体文件至statics/fonts/目录;3. 在css文件中添加@font-face规则并…

    2025年12月10日 好文分享
    000
  • PHPCMS系统的基本配置参数说明和调整

    phpcms系统的基本配置参数包括数据库、缓存、静态化、安全、邮件、调试和模板配置。1. 数据库配置需设置连接参数、使用utf8mb4字符集,并优化连接池与查询缓存,同时控制用户权限;2. 缓存配置支持页面缓存、数据缓存,并可集成memcached或redis,根据访问量调整缓存时间;3. 静态化配…

    2025年12月10日 好文分享
    000
  • 在Nginx服务器上部署PHPCMS的配置要点

    部署phpcms到nginx的核心要点包括:1. 配置nginx正确解析php文件,2. 处理url重写以支持伪静态地址,3. 确保静态资源访问正常。关键在于通过try_files指令将非静态文件请求转发给index.php处理,实现phpcms的seo友好url;通过fastcgi_pass配置n…

    2025年12月10日 好文分享
    000
  • PDF怎样生成?TCPDF与DomPDF对比

    tcpdf适合高性能和精细控制,dompdf适合快速开发。1.tcpdf更底层灵活,性能好,控制力强,但学习曲线陡,html支持有限;2.dompdf基于html/css,易上手,开发快,但性能较差,控制力弱,css支持不完整。根据需求选择:大量数据或精确布局选tcpdf,熟悉html/css且追求…

    2025年12月10日 好文分享
    000
  • 网络爬虫如何用PHP开发?DOM数据抓取技巧分享

    使用php开发网络爬虫可通过file_get_contents()或curl获取网页内容,再结合domdocument和domxpath解析并提取dom结构中的数据。1.常用函数包括file_get_contents()用于获取网页源码、domdocument用于解析html、domxpath用于通…

    2025年12月10日 好文分享
    000
  • PHP怎样转换字符串编码 PHP编码转换的常见问题解决

    php转换字符串编码的核心是使用mb_convert_encoding函数,但需确保环境已启用mbstring扩展。1.确定原始编码,可通过mb_detect_encoding检测或手动指定;2.使用mb_convert_encoding进行转换,并处理失败情况;3.检查php.ini中是否启用mb…

    2025年12月10日 好文分享
    000
  • PHPCMS和织梦CMS的广告管理功能对比评测

    phpcms在广告管理的灵活性和自定义能力上更强,而织梦cms则更直观易用。1.phpcms通过自定义内容模型和标签系统实现复杂广告逻辑,适合深度定制需求;2.织梦内置独立广告模块,操作简单,适合快速上线广告;3.phpcms支持更高级的投放策略如按分类、用户组、时间等条件展示广告,而织梦需二次开发…

    2025年12月10日 好文分享
    000
  • 解决表单提交后JavaScript启用按钮状态丢失的问题:使用Fetch API实现异步提交

    本教程旨在解决Web开发中常见的按钮状态丢失问题。当用户通过JavaScript启用一个按钮,但表单提交导致页面刷新时,按钮会恢复到初始禁用状态。文章将深入探讨此问题根源,并提供使用Fetch API进行异步表单提交的解决方案,确保按钮状态在服务器端处理后仍能保持,从而提升用户体验。 传统表单提交与…

    2025年12月10日
    000
  • 解决表单提交后JavaScript启用按钮失效的问题:使用Fetch API实现异步交互

    本文探讨了表单提交导致页面重载,进而使JavaScript启用的按钮恢复禁用状态的问题。通过详细介绍并提供Fetch API的实现示例,文章阐述了如何利用异步请求避免页面刷新,从而确保前端交互状态的持久性,提升用户体验,并提供了相关的代码示例和注意事项。 在Web开发中,我们经常会遇到这样的场景:一…

    2025年12月10日
    000

发表回复

登录后才能评论
关注微信