jdk8下HashMap源码分析实现原理

1.HashMap
继承:抽象类AbstractMap
实现:接口Map、Cloneable、Serializable
在这里插入图片描述
2.HashMap的初始化
四个构造函数:
在这里插入图片描述
先看看无参构造函数
在这里插入图片描述
构建一个HashMap实例,并初始化loadFactor=DEFAULT_LOAD_FACTOR
来看看loadFactor和DEFAULT_LOAD_FACTOR这两个属性的定义:
在这里插入图片描述
注释为:hash表的加载因子
在这里插入图片描述
注释为:当构造函数没有指定加载因子时使用此值

可以看到无参够咱函数的加载因子默认为0.75
至于加载因子的作用后面再讲

现在我们执行此代码:
在这里插入图片描述
看看内存图:
在这里插入图片描述
那么HashMap怎么保存数据的呢?来看看添加方法put()
3.HashMap的put();
在这里插入图片描述
put方法有四种,先看看第一种
put(K key, V value),源码如下:
在这里插入图片描述

直接调用putVal(),第一个参数调用了hash(key),来看看此方法:
在这里插入图片描述
功能:对传入的key进行hash处理
原理:对传入的key的hashCode值key的hashCode进行逻辑右移16位(>>>16)后的值进行位异或运算(^)
如果key为null,返回0

来看看putValputVal(int hash, K key, V value, boolean onlyIfAbsent,boolean evict) ,源码如下:
在这里插入图片描述

总结:
扩容并将单向链表长度>=8的转换为红黑树结构
扩容分两种情况:
a.第一次添加数据时
b.添加数据后数据个数大于阈值threshold
在这里插入图片描述
threshold为控制是否扩容的阈值,一般<=HashMap中存数据的Node[]的容量,计算方式:容量*loadFactory,所以loadFactory的值也影响着扩容操作

看看扩容方法resize():
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值