集合框架----源码解读LikedeHashMap篇
admin
2024-02-28 01:10:44
0

1.官方介绍

Hash表和链表实现Map接口,具有可预测的迭代顺序。该实现与HashMap的不同之处在于它维护了一个贯穿其所有条目的双向链表。该链表定义了迭代顺序,通常是键被插入到映射中的顺序(插入顺序)。注意,如果密钥被重新插入到映射中,插入顺序不会受到影响。当m . includekey ( k )在调用之前立即返回true时调用(如果m . put ( k , v ) ,则密钥k被重新插入到映射m中)。)
这种实现使其客户端免受HashMap (和Hashtable )提供的不特定的、通常是混沌的排序的影响,而不会增加与树图相关的成本。它可以用来制作与原图顺序相同的地图副本,而不管原图的实现方式如何:

void foo(Map m) {
           Map copy = new LinkedHashMap(m);
           ...
       }

这种技术特别有用,如果一个模块在输入上取一个映射,复制它,然后返回由复制的顺序决定的结果。(客户一般赞赏以相同的顺序返回的东西。)
提供了一个特殊的构造函数来创建一个链接哈希映射,其迭代的顺序是它的条目最后被访问的顺序,从最近访问到最近访问( access-order )。这种映射非常适合构建LRU缓存。调用put、putIfAbsent、get、getOrDefault、计算、计算IfAbsent、计算IfPresent或合并方法得到对应条目的访问(假设它在调用完成后存在)。替换方法仅在值被替换的情况下导致条目的访问。putAll方法为指定地图中的每个映射生成一个入口访问,顺序为键值映射由指定地图的入口集合迭代器提供。没有其他方法。

可以重写 removeEldestEntry(Map.Entry) 方法,以强加在将新映射添加到映射时自动删除过时映射的策略。
此类提供所有可选的 Map 操作,并允许空元素。与 HashMap 一样,它为基本操作(添加、包含和删除)提供恒定时间性能,假设哈希函数在存储桶之间正确分散元素。由于维护链表的额外费用,性能可能略低于HashMap,但有一个例外:对LinkedHashMap的集合视图进行迭代需要与地图大小成正比的时间,无论其容量如何。在HashMap上进行迭代可能会更昂贵,需要与其容量成正比的时间。

链接的哈希映射有两个影响其性能的参数:初始容量和负载系数。它们的定义与HashMap精确。但请注意,对于此类,为初始容量选择过高值的惩罚不如 HashMap 严重,因为此类的迭代时间不受容量的影响。
请注意,此实现不同步。如果多个线程同时访问链接的哈希映射,并且至少有一个线程在结构上修改了映射,则必须在外部同步该映射。这通常是通过在自然封装地图的某些对象上进行同步来实现的。如果不存在这样的对象,则应使用 Collections.syncdMap 方法“包装”映射。最好在创建时执行此操作,以防止意外不同步访问map:

 Map m = Collections.synchronizedMap(new LinkedHashMap(...));

结构修改是添加或删除一个或多个映射的任何操作,或者在访问顺序链接哈希映射的情况下,影响迭代顺序。在插入顺序链接哈希映射中,仅更改与映射中已包含的键关联的值不是结构修改。在访问顺序链接哈希映射中,仅使用 get 查询映射是一种结构修改。)
由迭代器方法返回的迭代器返回的所有此类集合视图方法返回的迭代器是快速失败的:如果在创建迭代器后的任何时间对映射进行结构修改,则除了通过迭代器自己的 remove 方法之外,迭代器将抛出 ConcurrentModificationException。因此,面对并发修改,迭代器会快速而干净地失败,而不是冒着在未来不确定的时间出现任意、非确定性行为的风险。

请注意,无法保证迭代器的快速故障行为,因为一般来说,在存在不同步的并发修改的情况下,不可能做出任何硬保证。Fail-fast 迭代器会尽最大努力抛出 ConcurrentModificationException。因此,编写一个依赖于此异常的正确性的程序是错误的:迭代器的快速故障行为应仅用于检测错误。
由此类的所有集合视图方法返回的集合的拆分器方法返回的拆分器是后期绑定的、快速失败的,并且还报告 Spliterator.ORDERED。
此类是 Java 集合框架的成员。

2. LikedeHashMap的底层原理

LikedeHashMap是继承HashMap,这里只讲述,LikedeHashMap维护了一个Entry的双向链表,保证Entry的顺序,可以理解为有序的HashMap. LikedeHashMap存放不是存放在数组里面的了,是存放在一个双向链表,当发生哈希冲突就会直接放在最后一个位置这样做解决了无序的问题,完美的继承了双向链表的特性,查询速度变慢。

相关内容

热门资讯

黄金暴跌,市场总有轮回。 今天不聊别的,还是聊黄金。但今天为了说清楚黄金,我会先分析同样经历了暴跌的比特币、以太坊等crypt...
2025年净利最高预亏2.9亿... 北京商报讯(记者 丁宁)2月2日,双鹭药业(002038)盘中触及跌停,截至北京商报记者发稿,双鹭药...
盘点2025信托业(二)|新监... 中国网财经2月2日讯 2025年,信托行业监管制度体系经历根本性重塑,“1+N”政策框架落地生根,为...
中国国航2026年春运计划执行... 中国国际航空股份有限公司(下称“国航”)2月2日宣布,2026年春运将全面升级运力投入,在册飞机数量...
原创 今... 一家公司,在不到一个月的时间里,股价像坐上了火箭,一口气连拉17个涨停板,价格翻了4倍多。 就在所有...
脑出血后昏迷不醒有什么治疗方法... 脑出血是一种发病急、进展快、致死致残率极高的急性脑血管疾病,其发病率约占全部脑卒中的20%~30%,...
原创 今... 今天A股跌得让人心慌,商业航天、黄金、农业,热点一个接一个熄火。 但在一片惨绿中,有一个板块却像打了...
2026年存款搬家,有望为A股... 根据财通证券测算,2026年企业与居民中长期存款的到期规模在57.3万亿元,而居民中长期存款到期规模...
两部门发文明确增值税进项税额抵... 财政部 税务总局 关于增值税进项税额抵扣等有关事项的公告 财政部 税务总局公告2026年第13号 根...
兴业银行多位经理被禁止从事银行... 据国家金融监督管理总局大连监管局2月2日公开的行政处罚信息显示,兴业银行股份有限公司大连分行因信贷业...
原创 金... 深圳水贝市场里,一位女士快速计算着价格,掏出银行卡支付了近12万元,买下100克金条。 黄金价格正在...
韩国股市大跌触发熔断机制 1日,韩国首尔,中区一家银行交易室的电子屏显示韩国综合股价指数(KOSPI)。视觉中国/图 韩国股市...
尿色加深、皮肤泛黄时,你的肝可... 生活中,不少人发现尿色变深、皮肤泛黄时,会误以为是喝水少、上火或肤色问题,简单调整后便不再关注。可这...
30亿元红包!千问宣布 2月2日,千问APP宣布投入30亿元启动“春节请客计划”,以免单形式请全国人民在春节期间吃喝玩乐,感...
周生生足金挂坠被检测出含铁银钯... 编者按:维护消费者权益,守护消费安全。央广网啄木鸟消费者投诉平台,保障消费者合法权益,为新消费时代保...
中国AI应用春节红包大战 阿里... 中国科技巨头为推广旗下人工智能(AI)产品重演11年前的红包大战,继腾讯和百度后,同样在追赶字节跳动...
最新!多家银行,紧急调整! 近期,国际黄金与白银价格在创下历史新高后剧烈波动。2月2日,金银价格显著回调,黄金期货一度跌破每盎司...
米兰冬奥中国代表团成立丨冰雪热... 聚焦健康中国 冬奥会 (第一健康报道北京 实习记者袁正杰) 米兰冬奥会中国体育代表团正式成立,标志着...
i茅台:月活用户超1531万,... 1499元飞天上架已满月,i茅台披露关键数据。 2月2日,据“小茅i茅台”微信公号,i茅台表示,“这...
多重风险高悬 一批*ST公司拉... 伴随2025年度业绩预告密集发布,一批上市公司拉响退市风险“警报”。 据上海证券报初步统计,近期,已...