c++ map底层实现原理_面试:说一下HashMap的底层实现原理,我懵了

之前我们对Java集合框架一些常见的面试题做了一个总结式的回答:《【29期】Java集合框架 10 连问,你有被问过吗?》这篇开始针对29期中的一些比较重要的问题做详细的解答。

哈希表(hash table)也叫散列表,是一种非常重要的数据结构,应用场景及其丰富,许多缓存技术(比如memcached)的核心其实就是在内存中维护一张大的哈希表,而HashMap的实现原理也常常出现在各类的面试题中,重要性可见一斑。

本文会对java集合框架中的对应实现HashMap的实现原理进行讲解,然后会对JDK7的HashMap源码进行分析(JDK8会有所不同,需要了解的可自行阅读JDK8的HashMap源码)。

JDK7和JDK8中HashMap的大致变化是(这其实也是一个常被问道的面试题~):

1.7中采用数组+链表,1.8采用的是数组+链表/红黑树,即在1.7中链表长度超过一定长度后就改成红黑树存储。

1.7扩容时需要重新计算哈希值和索引位置,1.8并不重新计算哈希值,巧妙地采用和扩容后容量进行&操作来计算新的索引位置。

1.7是采用表头插入法插入链表,1.8采用的是尾部插入法。

在1.7中采用表头插入法,在扩容时会改变链表中元素原本的顺序,以至于在并发场景下导致链表成环的问题;在1.8中采用尾部插入法,在扩容时会保持链表元素原本的顺序,就不会出现链表成环的问题了。

目录

  • 什么是哈希表
  • HashMap实现原理
  • 为何HashMap的数组长度一定是2的次幂?
  • 重写equa

你可能感兴趣的:(c++,map底层实现原理)