当前位置: 首页 > 面试题库 >

请你解释一下hashMap具体如何实现的?

苏高远
2023-03-14
本文向大家介绍请你解释一下hashMap具体如何实现的?相关面试题,主要包含被问及请你解释一下hashMap具体如何实现的?时的应答技巧和注意事项,需要的朋友参考一下

考点:集合

Hashmap基于数组实现的,通过对key的hashcode & 数组的长度得到在数组中位置,如当前数组有元素,则数组当前元素next指向要插入的元素,这样来解决hash冲突的,形成了拉链式的结构。put时在多线程情况下,会形成环从而导致死循环。数组长度一般是2n,从0开始编号,所以hashcode & (2n-1),(2n-1)每一位都是1,这样会让散列均匀。需要注意的是,HashMap在JDK1.8的版本中引入了红黑树结构做优化,当链表元素个数大于等于8时,链表转换成树结构;若桶中链表元素个数小于等于6时,树结构还原成链表。因为红黑树的平均查找长度是log(n),长度为8的时候,平均查找长度为3,如果继续使用链表,平均查找长度为8/2=4,这才有转换为树的必要。链表长度如果是小于等于6,6/2=3,虽然速度也很快的,但是转化为树结构和生成树的时间并不会太短。还有选择6和8,中间有个差值7可以有效防止链表和树频繁转换。假设一下,如果设计成链表个数超过8则链表转换成树结构,链表个数小于8则树结构转换成链表,如果一个HashMap不停的插入、删除元素,链表个数在8左右徘徊,就会频繁的发生树转链表、链表转树,效率会很低。

 类似资料:
  • 本文向大家介绍请你说一下快排如何实现?相关面试题,主要包含被问及请你说一下快排如何实现?时的应答技巧和注意事项,需要的朋友参考一下 参考回答: 首先选择一个轴值,小于轴值的元素被放在数组中轴值左侧,大于轴值的元素被放在数组中轴值右侧,这称为数组的一个分割(partition)。快速排序再对轴值左右子数组分别进行类似的操作 选择轴值有多种方法。最简单的方法是使用首或尾元素。但是,如果输入的数组是正序

  • 本文向大家介绍请解释下你对EventEmitter的理解相关面试题,主要包含被问及请解释下你对EventEmitter的理解时的应答技巧和注意事项,需要的朋友参考一下 EventEmitter是Node基于发布订阅模式实现的第三方库events EventEmitter多用于被继承,而并非直接使用 EventEmitter中实现了on、emit、once、off、listen等其他功能 当on中监

  • 本文向大家介绍请你解释一下,什么是Web Service?相关面试题,主要包含被问及请你解释一下,什么是Web Service?时的应答技巧和注意事项,需要的朋友参考一下 考察点:web service   从表面上看,Web Service就是一个应用程序,它向外界暴露出一个能够通过Web进行调用的API。这就是说,你能够用编程的方法透明的调用这个应用程序,不需要了解它的任何细节,跟你使用的编程

  • 本文向大家介绍请你解释一下Jdo以及它的作用相关面试题,主要包含被问及请你解释一下Jdo以及它的作用时的应答技巧和注意事项,需要的朋友参考一下 考察点:JAVA API   JDO 是Java对象持久化的新的规范,为java data object的简称,也是一个用于存取某种数据仓库中的对象的标准化API。JDO提供了透明的对象存储,因此对开发人员来说,存储数据对象完全不需要额外的代码(如JDBC

  • 本文向大家介绍请解释一下TreeMap?相关面试题,主要包含被问及请解释一下TreeMap?时的应答技巧和注意事项,需要的朋友参考一下 考察点:key-value集合 TreeMap是一个有序的key-value集合,基于红黑树(Red-Black tree)的 NavigableMap实现。该映射根据其键的自然顺序进行排序,或者根据创建映射时提供的 Comparator进行排序,具体取决于使用的

  • 本文向大家介绍请你解释一下TCP为什么可靠一些相关面试题,主要包含被问及请你解释一下TCP为什么可靠一些时的应答技巧和注意事项,需要的朋友参考一下 考察点:TCP 三次握手,超时重传,滑动窗口,拥塞控制。