ConcurrentHashMap?
ConcurrentHashMap 是 Java 中的一个线程安全的哈希表,用于在多线程环境中高效地处理数据。这个类是 java.util.concurrent 包的一部分,提供了比 Hashtable 更高的并发性能,同时比简单地使用 Collections.synchronizedMap 包装 HashMap 提供了更好的线程安全性能。
5.1 设计和特性
ConcurrentHashMap 的主要特点是在不阻塞读操作的同时,通过使用分段锁(Segment Locking)或其他更高效的同步机制(如在 Java 8 及以后版本中的 CAS 操作),来减少更新操作的线程冲突。这允许高度的并发性,同时保持足够的线程安全。
5.1.1 Java 8 及之后版本:
从 Java 8 开始,ConcurrentHashMap 的实现摒弃了分段锁的概念,转而使用一种称为“synchronized”和 CAS(Compare-And-Swap)操作的结合方式来管理并发。这种方法减少了锁的使用,提高了表的并发性。它主要通过以下几种方式来实现:
- 节点的 CAS 替换:在进行插入操作时,如果期望位置为空,它会尝试使用 CAS 操作来直接设置节点。
- 使用 synchronized 锁:在更新链表或树的节点时,仍然需要使用锁,但是通过锁定较小的数据结构(如单个节点或链表),而不是整个桶或段,减少了锁的竞争。