HasMap之remove详解(一)

1. 导读

本期分享的是本人对于HashMap::remove的理解以及红黑树删除知识准备, 主要是围绕:
.1 removeNode;
.2 红黑树删除节点;
这两块内容来展开的;

2. HashMap::removeNode

我们先来看下HashMap::remove(JAVA8)的主流程:

HashMap::removeNode是分了两步: 找节点和删除节点;
.1 先根据key找到对应的节点, 非首节点时, 需要判断是红黑树还是链表;
.2 如果节点不存在, 返回null;
.3 找到对应节点后, 如果是红黑树, 调用红黑树的removeTreeNode方法删除节点;
.4 如果是链表, 判断是否为首节点, 如果是首节点, 直接移
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HashMap中的remove方法有两种形式。第一种是以key为参数的remove方法,只需要输入key,如果该key存在则会将对应的键值对从HashMap中删除。如果删除成功,则返回被删除的value值,如果key不存在,则返回null。 第二种是以key和value为参数的remove方法,需要同时判断key和value是否相等。只有当key和value都相等时,才会将对应的键值对从HashMap中删除。如果删除成功,则返回true,表示成功移除节点;如果key和value不匹配或者key不存在,则返回false。 需要注意的是,无论是哪种形式的remove方法,都是根据key的hash值来定位要删除的节点,并且在删除节点后会重新调整HashMap的结构保持数据的一致性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [【Java集合】HashMapremove()源码详解以及JDK1.7与JDK1.8的区别](https://blog.csdn.net/cy973071263/article/details/123129193)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [HashMapremove()方法详解](https://blog.csdn.net/cssnnd/article/details/106167413)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值