集合框架----源码解读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存放不是存放在数组里面的了,是存放在一个双向链表,当发生哈希冲突就会直接放在最后一个位置这样做解决了无序的问题,完美的继承了双向链表的特性,查询速度变慢。

相关内容

热门资讯

4月份银行理财规模环比增加2.... 钛媒体App 5月16日消息,银行理财市场在4月份迎来规模与收益的双增长。据华源证券廖志明团队发布的...
【光明日报】黑龙江:免签红利释... 5月10日早上7时,一辆国际大巴缓缓停靠在黑龙江绥芬河公路口岸入境大厅前。游客们提着大包小裹,依次走...
又一跨国高端化工合作项目落子乐... 5月15日,福华化学携手瑞士特种化学品企业科莱恩打造的创新型高端磷系无卤阻燃剂项目(以下简称“福华科...
鸿蒙智行:已拥有1951家销售... IT之家 5 月 15 日消息,鸿蒙智行智界 V9 发布会正在进行,官方透露目前已拥有 1951 家...
黄金、白银,直线大跌! 5月15日晚间,贵金属价格突然大跌! 截至记者发稿时,现货黄金跌超2%,暂报4553美元/盎司附近。...
央视《焦点访谈》聚焦!万兴科技... 深圳商报·读创客户端首席记者 谢惠茜 5月14日,中央电视台《焦点访谈》推出专题节目《扩能提质强服务...
东方嘉富人寿董事长履职半年被换... 文|达摩财经 东方嘉富人寿再度进行人事调整。 5月13日,东方嘉富人寿发布公告称,自2026年4月...
重返西决!文班19+6卡斯尔3... 【搜狐体育战报】北京时间5月16日NBA季后赛,客场作战的马刺以139-109击败森林狼,总比分4-...
原创 美... 十万亿美债为什么还没有崩盘?或许答案在于,中国的存在让局势与众不同。现在的美债就像一张看似脆弱的网,...
原创 茅... 最近打开股票软件看白酒板块,是不是心里拔凉拔凉的? 茅台又回到1300元区间了,五粮液跌破90元,洋...
茅台宣布涨价 5月15日深夜,“i茅台”APP发布公告称,按照随行就市、供需适配、量价平衡、相对平稳的原则,贵州茅...
最高涨200元!茅台官宣4款产... 贵州茅台(600519.SH)凌晨宣布涨价几款产品。 茅台数字营销平台“i茅台”今日(5月16日)发...
面向地方国资产融转型全链条,X... 5月15日,XOD创新投融资模式3.0产品发布会在广州举办。该产品主要面向地方国资产融协同创新转型提...
2026Q1:10家上市商超9... 截至4月30日,所有A股上市公司2026年Q1财报全部出炉,传统商超也晒出自己的成绩单。10家披露的...
入主盟科药业失利后,拟借款2.... 来源:时代周报-时代在线 继去年试图通过定增入主盟科药业(688373.SH)失败后,海鲸药业再度出...
同比激增86%、规模突破760... 图片来源:界面图库 界面新闻记者 | 孙艺真 今年以来,证券行业融资补血热潮持续升温。前5个月...
促进青年消费,扶持青年创业,上... 5月14日,上海市政协团青界别、经济界跨界别活动在市政协全过程人民民主实践点举行。 今年初,团市委立...
苹果股价昨日创收盘新高,站上3... IT之家 5 月 16 日消息,苹果公司股价昨日(5 月 15 日)收于 300.23 美元,首次站...
杭州首批配售型保障房正式入市 杭州首批配售型保障房正式入市 价格约为周边商品房5折,18日开始报名 不能入市交易,可由政府指定机构...
“后巴菲特时代”,伯克希尔调仓... 当地时间5月15日,伯克希尔披露了2026年一季度美股持仓报告。这是伯克希尔在巴菲特卸任CEO并由阿...