LinkedHashMap 的实现原理

一、概述

从源码里的第一段注释中,我们可以先了解到 LinkedHashMap 是通过哈希表和链表实现的,它通过 维护一个链表来保证对哈希表迭代时的有序性,而这个有序是指键值对插入的顺序。 另外,当向哈希表中重复插入某个键的时候,不会影响到原来的有序性。也就是说,假设你插入的键的顺序为 1 2 3 4 ,后来再次插入 2 ,迭代时的顺序还是 1 2 、3、 4 ,而不会因为后来插入的 2 变成 1 3 4 2 。(但其实我们可以改变它的规则,使它变成 1 3 4 2
LinkedHashMap 的实现主要分两部分,一部分是哈希表,另外一部分是链表。哈希表部分继承了 HashMap ,拥有了 HashMap 那一套高效的操作,所以我们要看的就是 LinkedHashMap 中链表的部分,了解它是如何来维护有序性的。
LinkedHashMap 的大致实现如下图所示,当然链表和哈希表中相同的键值对都是指向同一个对象,这里把它们分开来画只是为了呈现出比较清晰的结构。
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
### 回答1: LinkedHashMap是一种哈希表和链表相结合的存储结构,它通过将每个键映射到一个哈希表中的链表来实现。当用户插入、访问或删除一个键时,哈希表可以快速找到相关的链表中的键。LinkedHashMap还可以记住插入的顺序,以便按先进先出的顺序遍历它的元素。 ### 回答2: LinkedHashMapJava集合框架中的一个类,它继承自HashMap,并且还使用了双向链表来维护元素的顺序。 LinkedHashMap内部维护了一个由双向链表实现的哈希表,该哈希表存储了键值对(Entry)。每个Entry中除了包含键和值外,还包含了链表中的前驱节点和后继节点。这样就可以通过链表实现元素的有序性。 在LinkedHashMap中,有两种遍历顺序:插入顺序和访问顺序。插入顺序表示元素的顺序与它们被插入的顺序相同,而访问顺序表示元素的顺序与它们最近被访问的顺序相同。 当创建LinkedHashMap时,可以通过构造函数来指定使用插入顺序还是访问顺序。默认情况下,LinkedHashMap使用插入顺序。 在插入新元素时,LinkedHashMap会在哈希表中添加一个新的Entry,并将其插入到链表的尾部。如果已存在相同的键,LinkedHashMap会将原来的Entry更新为新的值。 在访问已存在的元素时,LinkedHashMap会将对应的Entry移动到链表的尾部。这样就可以实现按访问顺序进行遍历。 当哈希表中的元素超过了设定的阈值(loadFactor),HashMap会进行扩容操作。在扩容过程中,LinkedHashMap会依据插入顺序或访问顺序来重新计算元素在新的哈希表中的位置,从而保持元素的有序性。 总之,LinkedHashMap通过使用双向链表来维护元素的顺序,实现了按插入顺序或访问顺序进行遍历的功能。这种实现方式既提供了HashMap的高效性能,又保留了元素的有序性。 ### 回答3: LinkedHashMapJava中的一种数据结构,它是HashMap的一个子类。它使用了一个双向链表来维护元素的插入顺序。 LinkedHashMap实现原理如下: 1. LinkedHashMap维护了一个数组table,数组的每个元素都是一个双向链表的头节点,称为Entry。Entry中存储了键值对的数据以及指向前一个和后一个Entry的引用。 2. 在插入元素时,首先计算键的哈希值,然后根据哈希值找到对应的数组位置。如果该位置还没有元素,就将新元素作为头节点插入。如果该位置已经有元素,就将新元素插入到链表的末尾。 3. 在访问元素时,根据键的哈希值找到对应的数组位置,并遍历链表找到键对应的元素。由于链表是双向的,所以查找效率较高。 4. 在迭代元素时,可以选择按照插入顺序或者访问顺序进行。按照插入顺序时,只需要遍历链表即可。按照访问顺序时,可以通过将访问到的元素移到链表的末尾来实现。 LinkedHashMap实现原理可以保证元素的有序性。在多线程环境下,需要注意线程安全性,可以通过对访问操作进行同步来实现。 总之,LinkedHashMap通过使用双向链表来维护元素的插入顺序,并且通过哈希表来提高元素的查找效率。它是HashMap的一个扩展,为了提供有序的遍历能力而存在。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Night-Monkey

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值