Map

JDK:Java 开发工具包,就是 Java 的版本。

  • JDK1.7 = Java 7 版本
  • JDK1.8 = Java 8 版本(现在企业最常用、面试问得最多

1、HashMap 底层原理

答案

JDK1.8 底层:数组 + 链表 + 红黑树

元素以 key 哈希值 定位数组下标;

哈希冲突时挂链表,链表长度 ≥8 且数组长度≥64 转为红黑树

红黑树节点数 ≤6 退化为链表。

2、HashMap 默认初始容量、负载因子、扩容

答案

  • 默认初始容量:16
  • 默认负载因子:0.75
  • 扩容阈值:容量 × 0.75
  • 扩容规则:扩容为原来 2 倍,重新散列迁移元素。

3、为什么负载因子是 0.75

答案

平衡空间利用率哈希冲突概率

太小浪费空间,太大链表过长查询变慢,0.75 是折中最优值。

4、HashMap 为什么容量必须是 2 的幂次

答案

为了哈希寻址用 hash & (length-1) 代替取模运算,效率更高;

同时保证元素散列均匀,减少冲突。

5、JDK1.7 和 1.8 HashMap 区别

答案

  1. 1.7:数组 + 链表,无红黑树;1.8 加红黑树
  2. 1.7 头插法;1.8 尾插法
  3. 1.7 扩容易循环链表死循环;1.8 解决死循环问题
  4. 1.8 哈希扰动简化,性能更好

6、HashMap 线程安全吗?不安全有什么问题

答案

线程不安全多线程并发 put:

  1. 数据覆盖丢失
  2. JDK1.7 扩容形成环形链表,get 死循环
  3. 出现空指针、数据错乱

7、线程安全的 Map 有哪些

答案

  1. Hashtable:全方法加 synchronized,效率低,过时
  2. Collections.synchronizedMap:包装 HashMap,分段加锁粒度粗
  3. ConcurrentHashMap:并发首选,分段锁 / 细粒度锁,效率高

8、ConcurrentHashMap 底层原理

答案

JDK1.7:分段锁 Segment,每段独立加锁,并发度高;

JDK1.8:放弃分段锁 ,采用 CAS + synchronized 锁住链表 / 红黑树首节点,粒度更细、并发更高、底层同样数组 + 链表 + 红黑树。

9、HashMap 的 key 可以为 null 吗

答案

允许一个 key 为 null,放在下标 0 位置;

ConcurrentHashMap key 和 value 都不能为 null

10、HashMap 遍历方式有几种

答案

  1. 遍历 keySet
  2. 遍历 entrySet(效率最高)
  3. 迭代器遍历
  4. Lambda forEach

11、HashTable 和 HashMap 区别

答案

  1. Hashtable 线程安全,HashMap 不安全
  2. Hashtable 不允许 null 键值,HashMap 允许一个 null key
  3. Hashtable 默认容量 11,扩容 2 倍;HashMap 16、扩容 2 倍
  4. Hashtable 全局锁,性能差,不推荐使用

12、TreeMap 原理和特点

答案

底层 红黑树 ,可以按 key 自然排序 或 自定义比较器排序;

适合需要有序的场景。

面试一句话总结

HashMap 1.8 是数组 + 链表 + 红黑树,默认容量 16、负载因子 0.75、扩容 2 倍;线程不安全;并发用 ConcurrentHashMap,1.8 用 CAS + 锁首节点实现高并发;TreeMap 红黑树可排序;Hashtable 老旧低效不推荐。

相关推荐
巫山老妖1 小时前
鹅厂十年:三段式技术成长复盘
android·人工智能·程序员
阿巴斯甜1 小时前
List集合
android
ooseabiscuit2 小时前
Laravel6.x核心优化与特性全解析
android·开发语言·javascript
阿巴斯甜3 小时前
Kotlin 协程 Coroutine
android
Jomurphys4 小时前
Compose 适配 - 通过 UiMediaScope 获取设备信息
android·compose
阿巴斯甜4 小时前
必看12
android
阿巴斯甜4 小时前
必看11
android
solo_994 小时前
Perftto 使用命令添加标签
android
阿巴斯甜5 小时前
必看10
android