HashMap学习总结

HaspMap的特点:

HashMap<K,V>继承了AbstractMap<K,V>,实现了Map<K,V>, Cloneable, Serializable等接口

1、存储双值,以 key—value 的形式存储数据
2、可以通过key来寻找key—value的位置(元素的位置由key来决定),从而得到value的值
3、key可以为null,但是不能重复
4、比较适合查找工作,时间复杂度为O(1)
5、可以使用clone()方法
6、可以被序列化

源码分析:

1、HashMap如何通过 key 来计算 key-value 存储的位置

先通过key获取key.hashCode的值,并进行一系列的扰动处理,最后和 table.length(数组长度)-1进行按位与操作,得到对应的存储位置的下标。当 key 为 null 时,该下标默认为0,截取代码如下:

/**
 * 利用hashcode获取key对应的下标,当key为null时返回0
 * 引入h一方面是进行扰动处理,可以是得到的index更加的分散
 * 另一面可以在hashcode为负数时去掉负号
 * @param key
 * @return
 */
public int hash(K key){
   
    if(key == null){
   
        return 0;
    }
    int h = key
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值