HashMap解析

HashMap map=new HashMap() ;

1.new 初始化大小 - 16 扩展因子 0.75 

map.put()

1.获取table 为空创建 容积大小的Node[] 

2.hash key  与运算, 以该值为 index  获取 node[] 中的 值  

   创建新的值 node  ,如果存在hash碰撞 放入  该node.next 中 ,如果存在多个 相同hashkey ,

    如果超过了 threshold - 8 这会 替换node 为 treenode  成树 可能触发resize 操作

3.放入结束后如果检查 容积超过扩展大小, 从新扩展整个node[]  

    3.1 创建新的node[] 并循环整个老的node[] 从新赋值到新的node[] 中

map.remove 

 1.获取key hash 

2.如果是node  直接赋值node.next

   如果是 tree 直接操作红黑树异常节点

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值