【JDK1.8源码】ConcurrentHashMap并发容器图解

本文对比HashMap分析了ConcurrentHashMap的类图,强调了内部对象的安全发布以保证线程安全。在并发读写中,get操作通过volatile确保可见性,put操作则利用CAS、volatile和锁细化提高并发性能,避免全表锁,保证高并发下的数据一致性。
摘要由CSDN通过智能技术生成

目录

1.类图对比HashMap

2.并发实现

2.1 内部对象安全发布

2.2 并发读写

2.2.1 get读

2.2.2 put


1.类图对比HashMap

数据结构与HashMap类似,详情请戳,在HashMap的基础上在其API接口上进行了并发访问控制等实现,使其变得线程安全。

ConcurrentHashMap(CHM) HashMap(HM)

2.并发实现

2.1 内部对象安全发布

数据结构与HashMap对比可以发现table是大体相似的,而entrySet等返回的都是View的视图包装类。

防止直接发布内部容器,被意外修改,导致Map的不变式约束被破坏,数据不一致不完整。

读写操作都做了重写,当对entrySetView等进行修改时,会同步修改this map,不会存在意外修改导致的数据不一致状况。具体请见下节

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值