java-tip-HashMap

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java-tip-HashMap相关的知识,希望对你有一定的参考价值。

HashMap的基本查找过程:
先使用key.hashCode()生成哈希值,根据哈希值来确定key存放的位置
找到key在数组中的位置后,再使用key.equals()方法来找到指定的key。

 

1. 自定义的对象需要满足什么条件才能作为HashMap的Key?
    想要作为HashMap的Key必须满足两个条件:
   1) 重写hashCode()方法,一个对象的hashCode()决定对象在Hash表中存放的位置
       注:Object的hashCode()方法是根据对象的地址计算的。
   2) 重写equals()方法,equals()方法决定Hash表中是否存在这个对象
       注:Object的equals()方法只是比较地址
2. 关于android平台HashMap的装载因子和扩容
HashMap虽然提供了一个可以指定装载因子的构造函数,但是在实际的实现中并没有使用这个参数
它的装载因子总是0.75f

 

如果实际中key数量过多,会导致碰撞的hash变多,从而影响查找效率。
当size > capacity * 装载因子 时,HashMap会进行扩容。

 

HashMap的扩容步骤如下:
1. 申请新的数组,大小为旧的两倍
2. rehash -> 将现有的item放到新的hash表中

 

HashMap的扩容是个比较耗时的操作,因此,
我们在使用HashMap的时候,尽可能指定合适的Capacity以避免扩容。

以上是关于java-tip-HashMap的主要内容,如果未能解决你的问题,请参考以下文章

JAVA中重写equals方法为啥要重写hashcode方法说明

为什么重写equals()就必须重写hashCode(),什么情况下可以不重写hashCode()

重写了equals方法为何需要重写 hashCode

重写equals为什么要重写hashcode

为啥要重写toString方法和hashcode方法

Java基础重写equals需要重写hashcode