Hashmap的put、get流程

PUT流程

先通过put传入的Key去通过哈希算法与与运算得出数组下标

如果数组下标位置元素为空,则将key和value封装为Entry对象(JDK1,7中是Entry对象,JDK1.8中是Node对象)并放入该位置。

如果数组下标位置元素不为空,则要分情况讨论:
a. 如果是JDK1.7,则先判断是否需要扩容,如果要扩容就进行扩容,如果不用扩容就生成Entry对象,并使用头插法添加到当前位置的链表中。
b. 如果是JDK1.8,则会先判断当前位置上的Node的类型,看是红黑树Node,还是链表Node。

GET流程

首先通过hash(key)与length-1做与运算找到数组中的位置

再根据key的hash值,地址判断,equals判断是不是第一个元素

是则返回,不是则遍历链表继续判断,直到找到为止。

参考资料
【一分钟征服java面试官看完少走50年弯路】【数据结构】hashmap的get方法
【分分钟搞定八股文java面试题】阿里一面中的HashMap的Put方法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值