LinkedHashMap 能按插入顺序保存键值对,因其在 HashMap 基础上维护双向链表,put 时新节点同步追加至链表尾;默认为插入顺序,传入 true 可启用访问顺序以支持 LRU 缓存。

Java 中按插入顺序保存键值对,直接用 LinkedHashMap 就行——它在 HashMap 的基础上维护了一个双向链表,天然支持插入顺序(或访问顺序)遍历。
LinkedHashMap 是怎么记住插入顺序的
LinkedHashMap 内部除了哈希表,还额外维护了一个双向链表。每次调用 put() 添加新键值对时,新节点不仅插入哈希桶中,还会被追加到链表尾部。这样遍历 keySet()、values() 或 entrySet() 时,就自然按插入先后返回。
- 默认构造(如
new LinkedHashMap())启用插入顺序模式 - 若传入
true作为第三个参数(如new LinkedHashMap(16, 0.75f, true)),则切换为“访问顺序”——get/put 后该元素移到链表尾,适合实现 LRU 缓存 - 链表节点和哈希桶节点是同一个对象,不额外增加内存负担(相比用 List + Map 手动维护)
和 HashMap、TreeMap 的关键区别
三者都是 Map 接口实现,但行为不同:
- HashMap:不保证顺序,遍历结果可能每次都不一样(取决于扩容、hash 分布)
- TreeMap:按键的自然顺序或自定义 Comparator 排序,不是插入顺序
-
LinkedHashMap:唯一能稳定保持插入顺序的标准 Map 实现(且线程不安全,如需并发请考虑
ConcurrentHashMap+ 外部同步,或用Collections.synchronizedMap(new LinkedHashMap()))
一个实用的小例子
比如记录用户操作日志的前 5 条最近动作:
立即学习“Java免费学习笔记(深入)”;
MaprecentActions = new LinkedHashMap<>(16, 0.75f, true) { @Override protected boolean removeEldestEntry(Map.Entry eldest) { return size() > 5; // 超过 5 条就淘汰最久未访问的 } };
这里用了访问顺序 + removeEldestEntry 钩子,自动实现 LRU 行为。如果只是要纯插入顺序,去掉第三个参数 true 即可。
基本上就这些 —— 不需要自己封装,也不用额外排序,LinkedHashMap 开箱即用,轻量又可靠。










