hashmap 面试问题抄袭

内部数据机构是什么?

jdk7 是数组+链表, jdb8是数组+链表+红黑树

允许空键空值么?

key只能存在一个null值, value可以多个都为null

源码中的几个关键参数

  1. 初始容量: 16

为什么是16? 数组的大小是2的n次方, 初始化的时候,表不能太大也不能太小, 16作为一个经验值被采用

  1. 数组的大小为什么是2的n次方?

第一点:因为当length为2的N次方的时候,h & (length-1) = h % length, 求余运算可以转为与运算, 更快
第二点: 因为数学方面的研究, 长度为2的N次方的时候, 可以使hash分布更加离散

  1. 负载因子: 默认0.75

当 元素数量/表大小 > 0.75 时,要扩容为原来的两倍

put方法 过程是怎样的?

在这里插入图片描述
几个要点,

  1. table在put方法执行的时候才初始化.
  2. 两次resize扩容.
  3. 链表转为红黑树.

红黑树相关的问题

  1. 为什么用红黑树,有什么好处

红黑树是平衡树,可以将链表查找的O(n)复杂度,降为O(logN).查找能快点

线程安全么?

不安全

  1. 多线程同时put ,数据不一致
  2. jdk7 的头插法, 多线程情况下可能出现循环链表,cpu100%.

那么如何保证线程安全呢?

1.hashTable 方法上加锁,效率低
2. 使用ConcurrentHashMap

接下来就是考察ConcurrentHashMap,以及多线程的知识,或者考察其他数据结构了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值