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 老旧低效不推荐。

相关推荐
峥嵘life19 小时前
Android 蓝牙设备连接广播详解-2026
android·python·学习
MusingByte1 天前
别再裸用 Claude Code 了!安卓开发者必装 13 个官方推荐插件,效率翻 3 倍省 70% token
android
_李小白1 天前
【android opencv学习笔记】Day 29: 滤波算法之Sobel 边缘检测
android·opencv·学习
Dxy12393102161 天前
Python 操作 MySQL 事务:从入门到避坑
android·python·mysql
峥嵘life1 天前
Android getprop 属性限制详解:User 版本属性获取问题分析
android·开发语言·python·学习
一航jason1 天前
Speed Tools:一套低侵入的 Android 插件化 + 动态换肤 + 字体切换框架
android·插件化·组件化·换肤
李斯维1 天前
Jetpack 可观察数据容器 LiveData 的入门与基础使用
android·android jetpack
问心无愧05131 天前
ctf show web入门261
android·前端·笔记
alexhilton1 天前
车载系统中的可扩展UI:从UI嵌入到系统窗口编排
android·kotlin·android jetpack
Cloud_Shy6181 天前
解读《Effective Python 3rd Edition》:从练气到老魔(第一章 Item 4 - 6)
android·数据库·论文阅读·python