Java集合类型主要有哪些?以及各自原理

Java 集合框架在顶层设计上分为两大核心接口体系:Collection(存储单一元素)和 Map(存储键值对)。

1. List 体系(有序、可重复)

  • ArrayList
    • 底层原理 :基于动态数组实现。内存空间连续,支持通过索引进行 O(1) 时间复杂度的随机访问。
    • 扩容机制 :默认初始容量为 10(懒加载,首次 add 时初始化)。当容量不足时,触发扩容机制,新容量计算公式通常为 oldCapacity + (oldCapacity >> 1),即扩容为原容量的 1.5 倍 。扩容涉及底层数组的内存拷贝(System.arraycopy),开销较大。
  • LinkedList
    • 底层原理 :基于双向链表实现。内存空间不连续,每个节点(Node)包含数据项以及指向前驱和后继节点的指针。
    • 性能特征:不支持高效的随机访问,查找元素需遍历链表,时间复杂度为 O(n)。但在已知节点位置的情况下,插入和删除操作只需修改指针,时间复杂度为 O(1)

2. Set 体系(无序、不可重复)

  • HashSet
    • 底层原理 :内部完全包装了一个 HashMap。存入 HashSet 的元素被当作底层 HashMap 的 Key,而 Value 则统一指向一个静态不变的 Object 实例(PRESENT)。
    • 去重机制 :依赖 HashMap 的 Key 唯一性特质。存入元素时,依赖元素的 hashCode()equals() 方法判断是否重复。
  • TreeSet
    • 底层原理 :内部封装了 TreeMap,底层数据结构为红黑树(Red-Black Tree)
    • 排序机制 :元素必须实现 Comparable 接口,或者在构造时传入自定义的 Comparator。红黑树保证了元素在插入、删除、查找时均能维持 O(\\log n) 的时间复杂度,并保持严格的有序状态。

3. Map 体系(键值对)

  • HashMap (JDK 1.8)
    • 底层原理 :采用 数组 + 链表 + 红黑树 的混合结构。
    • 寻址算法 :向 Map 中 put 元素时,先计算 Key 的扰动 Hash 值(hash() ^ (hash() >>> 16)),然后通过 (n - 1) & hash(等价于取模运算,但位运算性能更高,前提是数组长度 n 必须是 2 的幂次方)定位到数组的槽位(Bucket)。
    • 冲突解决与树化 :发生哈希冲突时采用尾插法形成链表。当某一槽位的链表长度达到 8 且底层数组长度大于 64 时,链表将转化为红黑树,以保证在极端冲突下的查询时间复杂度从 O(n) 优化至 O(\\log n)
    • 扩容机制 :默认负载因子为 0.75。当 size > capacity * 0.75 时触发扩容,容量翻倍(2倍)。扩容时,元素位置要么保持在原槽位,要么移动到 原索引 + 原数组容量 的新槽位,避免了重新计算全部 Hash。
  • HashMap (JDK 1.8 以前)
    • 底层原理 :数据结构采用 数组 + 链表 。内部维护一个 Entry 数组,通过计算 Key 的 Hash 值来确定其在数组中的索引位置。当发生 Hash 冲突时,将新的键值对通过链表结构存储在对应的桶(Bucket)中。
    • 并发安全问题 :由于没有并发控制机制,在多线程环境下进行扩容(Resize)操作时,由于采用 头插法 (Head Insertion) 移动链表节点,可能会导致链表成环 ,从而在后续的 get 操作中引发死循环,导致 CPU 占用率飙升。此外,还存在数据覆盖丢失的风险。
    • 1.7 是头插法 (新节点插入链表头部),1.8 改为尾插法(新节点插入链表尾部),从而解决了扩容死循环的问题
    • 1.7 在发生大量 Hash 冲突时,链表过长会导致查询效率从 O(1) 退化为 O(n),而 1.8 引入红黑树将其优化为 O(\\log n)
  • ConcurrentHashMap (JDK 1.8)
    • 底层原理 :数据结构与 HashMap 保持一致(数组 + 链表 + 红黑树)。
    • 并发控制机制 :彻底废弃了 JDK 1.7 的分段锁(Segment),转而采用 CAS + synchronized 来实现极细粒度的锁。在进行 put 操作时,如果槽位为空,利用 CAS 操作无锁插入;如果槽位非空,则只对该槽位的首节点(链表头节点或红黑树根节点)加 synchronized 锁,这使得不同槽位之间的写入操作可以完全并发执行
  • ConcurrentHashMap (JDK 1.7)
    • 底层原理 :数据结构采用 Segment 数组 + HashEntry 数组 + 链表 。一个 ConcurrentHashMap 实例中包含由多个 Segment 组成的数组,每个 Segment 内部又维护着一个类似于 HashMap 的 HashEntry 数组
    • 并发控制机制 :核心思想是 分段锁 (Segment Locking) 。每个 Segment 继承了 ReentrantLock,从而充当锁的角色。在进行 put 操作时,程序会首先通过 Hash 定位到具体的 Segment,只对该 Segment 加锁,而不影响其他 Segment 的读写 。这意味着只要多个写入操作发生在不同的段中,它们就可以完全并行执行,默认支持 16 个线程并发写入。
    • 因为是继承自ReentrantLock,因此就有大量的AQS相关的队列,因此浪费很大很大
相关推荐
SimpleLearingAI5 小时前
聚类算法详解
算法·数据挖掘·聚类
刀法如飞6 小时前
Go 字符串查找的 20 种实现方式,用不同思路解决问题
算法·面试·程序员
Dlrb12118 小时前
C语言-指针数组与数组指针
c语言·数据结构·算法·指针·数组指针·指针数组·二级指针
WL_Aurora8 小时前
Python 算法基础篇之集合
python·算法
平行侠8 小时前
A15 工业路由器IP前缀高速检索与内存压缩系统
网络·tcp/ip·算法
阿旭超级学得完9 小时前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表
li星野9 小时前
位运算 & 数学 & 高频进阶九题通关(Python + C++)
c++·python·学习·算法
jerryinwuhan9 小时前
hello算法,简单讲(1)
算法·排序算法
y = xⁿ9 小时前
20天速通LeetCodeday15:BFS广度优先搜索
算法·宽度优先
400分9 小时前
吃透RAG核心-----语义检索与关键字检索底层原理
算法·架构