HashMap面试题

HashMap面试题

数据结构

jdk1.8之前,HashMap是由数组+链表组成的。数组是HashMap的主体,链表主要为了解决哈希冲突(拉链法解决冲突)。
jdk1.8以后,当链表长度大于8,并且当前数组长度大于64的时候,索引位置上的所有数据改用红黑树存储。
目的:为了提高性能和减少搜索时间。

为什么到8时转成红黑树,到6时转成链表


TreeNodes(红黑树)占用空间是普通Nodes(链表)的两倍,为了时间和空间的权衡。
节点的分布频率会遵循泊松分布,链表长度达到8个元素的概率为0.00000006,几乎是不可能事件.
为什么转化为红黑树的阈值8和转化为链表的阈值6不一样,是为了避免频繁来回转化。

特点

  1. 存取无需
  2. key、value都可以是null,但是key只能有一个null
  3. key位置是唯一的,底层的数据结构控制键的
  4. jdk8之前是链表+数组,8之后是链表+数组+红黑树
  5. 链表长度大于8且数组长度大于64,链表转化成红黑树,为了提高查询效率。

哈希碰撞

何时发生哈希碰撞?

两个元素key计算的哈希值相同就会生产哈希碰撞

如何解决哈希碰撞

jdk8之前使用链表解决哈希碰撞,jdk8之后用链表+红黑树解决。

如果两个key的哈希值相同,如何存储

hashcode相同通过equals比较内容是否相同,
相同:新的value覆盖就得value
不同:将新的键值对添加到哈希表中

哈希冲突的解决方法

拉链法

使用数组+链表的方式存储
使用:HashMap

开放地址法

如果哈希冲突了就继续往后找,知道找到一个为空的位置为止。
使用:ThreadLocalMap

再散列法

如果发生哈希冲突,就再次散列,知道不发生冲突为止。

扩容

当HashMap中元素个数超过数组大小*loadFactor时,进行扩容,loadFactor默认0.75
每次扩容一倍

为什么HashMap的长度一定是2的次幂呢?

参考 https://blog.csdn.net/Tane_1018/article/details/103392267

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: HashMap是Java中的一个常用数据结构,它的底层是由hash数组和单向链表实现的。每个数组元素都是一个链表,通过Node内部类实现了Map.Entry接口来存储键值对。HashMap通过put和get方法来存储和获取数据。\[1\] 在重写equals方法时,我们需要同时重写hashCode方法。这是因为在HashMap中,查找value是通过key的hashCode来进行的。当找到对应的hashCode后,会使用equals方法来比较传入的对象和HashMap中的key对象是否相同。因此,为了保证正确的查找和比较,我们需要同时重写equals和hashCode方法。\[2\]\[3\] HashMap在什么时候进行扩容呢?当HashMap中的元素数量超过了负载因子(默认为0.75)与当前容量的乘积时,就会进行扩容。扩容是为了保持HashMap的性能,因为当元素数量过多时,链表的长度会变长,查找效率会下降。扩容的过程是创建一个新的数组,将原数组中的元素重新分配到新数组中,然后将新数组替换为原数组。\[3\] #### 引用[.reference_title] - *1* *2* *3* [史上最全Hashmap面试总结,51道附带答案,持续更新中...](https://blog.csdn.net/androidstarjack/article/details/124507171)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值