Java 集合 HashMap ConcurrentHashMap

参考链接:

https://www.cnblogs.com/qiumingcheng/p/5259892.html

https://my.oschina.net/hosee/blog/639352

1. HashMap为什么是线程不安全的?

HashMap底层是一个Entry数组。如果两个Key的Hash值相同,则会产生碰撞冲突。

HashMap扩容时会生成一个新的数组。

2. ConcurrentHashMap

ConcurrentHashMap允许多个修改操作并发进行,其关键在于使用了锁分离技术。它使用了多个锁来控制对Hash表的不同部分进行的修改。ConcurrentHashMap内部使用段(Segment)来表示这些不同的部分,每个段其实就是一个小的HashTable, 它们有自己的锁。只要多个修改操作发生在不同的段上,它们就可以并发进行。

ConcurrentHashMap是线程安全的类,并不能保证使用了ConcurrentHashMap的操作都是安全的。

ConcurrentHashMap的get不需要加锁,put操作需要加锁。

 

转载于:https://my.oschina.net/u/3781047/blog/1628709

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值