JDK1.8:JAVA数据结构一:HashMap最经典解析

HashMap
掌握好HashMap要从底层看起:
public class HashMap<K,V> extends AbstractMap<K,V>
implements Map<K,V>, Cloneable, Serializable
HashMap继承AbstractMap实现Map、Cloneable 、Serializable接口
Cloneable标志接口,表示该对象能被克隆,能使用Object.clone()方法。
Serializable也是标志接口,表示对象可以被序列化。
HashMap底层源码解析:
HashMap的链式结构:在这里插入图片描述 这解决了HashMap的链式结构
HashMap的桶结构:
HashMap实现Map接口。Map接口内置了interface Entry<K,V> {}接口,里面有方法:
K getKey();
V getValue();
V setValue(V value);
boolean equals(Object o);
int hashCode();
接下来的三个主要是用来构造比较器
1、Returns a comparator that compares {@link Map.Entry} in natural order on key.比较器
在key上构造比较器
2、Returns a comparator that compares {@link Map.Entry} in natural order on value.
在这里插入图片描述
在value上构造比较器
3、
在这里插入图片描述
根据给出的比较器器来构造比较器
方法requireNonNull,主要以判断对象cmp是否为空,若为空抛出NullPointerException异常。
1、构造方法
HashMap()
构造一个具有默认初始容量 和默认加载因子的空 HashMap。
HashMap(int initialCapacity)
构造一个带指定初始容量和默认加载因子 (0.75) 的空 HashMap。
HashMap(int initialCapacity, float loadFactor)
构造一个带指定初始容量和加载因子的空 HashMap。
HashMap(Map<? extends K,? extends V> m)
构造一个映射关系与指定 Map 相同的新 HashMap。

有了上面的基础介绍,接下来专门讲解常用的put方法:
public V put(K key, V value) {
return putVal(hash(key), key, value, false, true);
}
进一步看方法putVal(hash(key), key, value, false, true);
在这里插入图片描述下回分解

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值