concurrenthashmap保证线程安全
时间: 2023-12-12 21:34:06 浏览: 80
阿里面试题:ConcurrentHashMap为什么是线程安全的?
ConcurrentHashMap是Java中线程安全的哈希表实现。它通过使用锁分段技术来实现线程安全。在JDK1.7中,ConcurrentHashMap采用分段锁实现线程安全。将数据分为一段一段存储,给每段数据分配一个锁,当一个线程占用锁访问其中一段数据时,其他段的数据也能被访问。在JDK1.8中,ConcurrentHashMap采用CAS和synchronized实现线程安全。synchronized只锁定当前链表或者红黑树的首节点,只要不发生hash冲突,就不会产生并发,效率大大提高。ConcurrentHashMap由分段锁Segment数组和节点HashEntry数组组成。分段锁Segment实现了ReentranLock,因此Segment是可重入锁。这种设计使得ConcurrentHashMap在高并发环境下具有较好的性能和可伸缩性。
阅读全文