LinkedHashMap使用

说明:本文介绍 Java 中 LinkedHashMap 的使用。

与 HashMap 的区别

LinkedHashMap,是 HashMap 的子类,是在 HashMap 的基础上维护了双向链表。

这就让 LinkedHashMap 中的元素能保持有序,按元素插入的顺序。

使用

在实际的使用中,双列集合,除了需要元素保持有序,我们可以使用 LinkedHashMap。

LinkedHashMap 还能当作最近最少使用(LRU)的缓存容器来使用,如下:

java 复制代码
import java.util.LinkedHashMap;
import java.util.Map;

/**
 * 最近最少使用(LRU)的缓存容器
 */
public class LinkedHashMapCache extends LinkedHashMap<String, Object> {

    /**
     * 缓存最大容量
     */
    private final int maxCapacity;

    public LinkedHashMapCache(int maxCapacity) {
        super(maxCapacity, 0.75f, true);
        this.maxCapacity = maxCapacity;
    }

    /**
     * 超出最大容量,移除最近最少使用的元素
     * 最近最少使用的标准:最近未被访问的元素
     */
    @Override
    protected boolean removeEldestEntry(Map.Entry<String, Object> eldest) {
        return size() > maxCapacity;
    }
}

使用,存满容器后再存入一个元素,查看容器内的元素情况

java 复制代码
public class LinkedHashMapDemo {
    public static void main(String[] args) {
        LinkedHashMapCache linkedHashMapCache = new LinkedHashMapCache(6);
        linkedHashMapCache.put("1", "a");
        linkedHashMapCache.put("2", "b");
        linkedHashMapCache.put("3", 1);
        linkedHashMapCache.put("4", "d");
        linkedHashMapCache.put("5", "e");
        linkedHashMapCache.put("6", "f");
        System.out.println("init:" + linkedHashMapCache);

        linkedHashMapCache.get("1");
        linkedHashMapCache.get("2");
        linkedHashMapCache.put("3", Integer.parseInt(linkedHashMapCache.get("3").toString()) + 1);
        linkedHashMapCache.put("7", "g");
        System.out.println("used:" + linkedHashMapCache);
    }
}

以下结论:

  • 存入的元素有序,开始按元素插入顺序,元素被访问后移到末尾;

  • 容器存满后,再存入一个元素,放到容器末尾,删除首位元素;

基于 LinkedHashMap 以上特性,可以作为一个最近最少访问(LRU)的缓存容器使用。

实际场景,如系统中需要体现最近系统活跃的十个用户信息,就可以用 LinkedHashMap。

(当然,存对象,需要重写 equals 和 hashCode 方法,或者也可以存用户 ID,展示时再用这些 ID 集合查数据库的用户信息)

相关推荐
荣江几秒前
Hermes Agent 代码仓库打包工具使用指南(repomix-rs 高性能版)
后端
王某某人3 分钟前
LangChain4j 入门:Java 程序员的第一个 AI 对话程序
人工智能·后端
码农刚子8 分钟前
从零开始:在 Windows 服务器上部署 Node.js 项目(小白实战教程)
后端·node.js
Cache技术分享8 分钟前
435. Java 日期时间 API - Clock 灵活获取当前时间
前端·后端
浩子coding17 分钟前
通过 Spring AI Alibaba 源码,看如何玩转 ReAct 智能体范式
人工智能·后端
技术小结-李爽24 分钟前
【工具】Maven的下载、安装、使用
java·maven
极创信息27 分钟前
Linux挖矿病毒深度清理实战教程,从进程隐藏、Rootkit驻留到彻底根除
java·大数据·linux·运维·安全·tomcat·健康医疗
星浩AI28 分钟前
合规项目大模型如何部署?硬件选型 + vLLM/LMDeploy 实战
pytorch·后端·llm
努力成为AK大王33 分钟前
并发编程的核心挑战、优化方案与核心知识点总结
java·开发语言·数据库
云烟成雨TD36 分钟前
Agent Scope Java 2.x 系列【10】技能(Skill)
java·人工智能·agent