内部数据机构是什么?
jdk7 是数组+链表, jdb8是数组+链表+红黑树
允许空键空值么?
key只能存在一个null值, value可以多个都为null
源码中的几个关键参数
- 初始容量: 16
为什么是16? 数组的大小是2的n次方, 初始化的时候,表不能太大也不能太小, 16作为一个经验值被采用
- 数组的大小为什么是2的n次方?
第一点:因为当length为2的N次方的时候,h & (length-1) = h % length, 求余运算可以转为与运算, 更快
第二点: 因为数学方面的研究, 长度为2的N次方的时候, 可以使hash分布更加离散
- 负载因子: 默认0.75
当 元素数量/表大小 > 0.75 时,要扩容为原来的两倍
put方法 过程是怎样的?
几个要点,
- table在put方法执行的时候才初始化.
- 两次resize扩容.
- 链表转为红黑树.
红黑树相关的问题
- 为什么用红黑树,有什么好处
红黑树是平衡树,可以将链表查找的O(n)复杂度,降为O(logN).查找能快点
线程安全么?
不安全
- 多线程同时put ,数据不一致
- jdk7 的头插法, 多线程情况下可能出现循环链表,cpu100%.
那么如何保证线程安全呢?
1.hashTable 方法上加锁,效率低
2. 使用ConcurrentHashMap