java基础面试题总结——集合框架

1. 在Java中,HashMap中是用哪些方法来解决哈希冲突的?

A. 开放地址法

B. 二次哈希法

C. 链地址法

D. 建立一个公共溢出区

答案:C

解析:

  • 开放地址法:哈希冲突后,在数组剩余空位中寻找空位进行存储,具体方式有线性探测法和二次探测法:

a. 线性探测:空白单元,当数据通过哈希函数计算应该放在n这个位置,但是n这个位置已经有数据了,那么接下来就应该查看n+1位置是否空闲,再查看n+2位置,依次类推

b. 二次探测:每次探测过程为n+1,n+4,n+9,以此类推,二次探测的步数是原始位置相隔的步数的平方;相比于线性探测法,二次探测更有助于避免数据扎堆,使其更快找到空位

a. 随机探测法:由于线性探测和二次探测同样会存在“主簇现象”(大量元素扎堆挤在同一块区域),因此探测过程也需要进一步增加随机性,在冲突时,对于探测步长采用随机函数计算得到,该随机函数的随机种子初始化时就将其确定下来,便于后续查找

采用开放地址发的hash表的容量需要设置为质数,否则将出现探测过程中某些步长无法搜索整个数组空位的情况

  • 链地址法:将hash之后相同位置的元素放到同一个位置,形成一个链表(链表长度超过某个值后转换为红黑树,提高查找效率)进行存储;java中的Hashmap默认是采用这种方法

  • 二次哈希法:第一次hash后产生冲突,继续进行另外一次不同的hash运算,直到得到的地址不再产生冲突为止;java的Hashmap中元素个数达到某个程度后继续使用链地址法和开放地址法将拖慢查找和插入效率,因此需要对其中每个元素采用二次哈希,将元素分摊到扩容之后的新hash桶中

  • 建立一个公共溢出区:另外新开辟一个hash桶来存放旧桶中冲突的元素

你可能感兴趣的:(java基础面试题总结——集合框架)