美文网首页
java基础面试题总结——集合框架

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

作者: 天渊hyominnLover | 来源:发表于2018-08-15 10:55 被阅读10次

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桶来存放旧桶中冲突的元素

相关文章

  • 一篇文章,全面解读Android面试知识点

    Java Java基础 Java集合框架 Java集合——ArrayList Java集合——LinkedList...

  • Java集合框架面试题

    标签(空格分隔): Java集合框架 面试题汇总 1. 什么是Java集合框架?请列举出集合(Collection...

  • Java基础

    Java基础 集合基础 集合框架 多线程基础 多线程框架 反射 代理 集合基础 ArrayList LinkedL...

  • Java基础面试总结

    【面试汇总】Java面试题-1Java面试题-2 【集合】Java集合及concurrent并发包总结(转)Jav...

  • 集合相关

    Java面试题 1.Java集合框架是什么?说出一些集合框架的优点? 集合框架的部分优点如下: 使用核心集合框类降...

  • java集合框架知识点

    java集合框架的知识点接口 集合 元素 java key 阅读2771Java集合框架作为Java编程语言的基础...

  • java集合框架学习总结

    title: java集合框架学习总结 tags:集合框架 categories:总结 date: 2017-03...

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

    1. 在Java中,HashMap中是用哪些方法来解决哈希冲突的? A. 开放地址法 B. 二次哈希法 C. 链地...

  • Java面试题目录

    垃圾回收 面试题-Java基础-垃圾回收 java垃圾回收 集合 40个Java集合面试问题和答案 Java集合框...

  • Java面试题目录

    垃圾回收 面试题-Java基础-垃圾回收 java垃圾回收 集合 40个Java集合面试问题和答案 Java集合框...

网友评论

      本文标题:java基础面试题总结——集合框架

      本文链接:https://www.haomeiwen.com/subject/rrvibftx.html