线程安全的哈希表ConcurrentHashMap

1. HashTable

不推荐使用,无脑给各种方法加锁

2.ConcurrentHashMap

多线程下推荐使用

  1. 锁粒度控制

HashTable直接在方法上加synchronized,相当于对哈希表对象加锁,一个哈希表只有一把锁。多线程环境下,无论线程如何操作哈希表,都会产生锁冲突。
image.png
而ConcurrentHashMap每个哈希桶都有自己的锁,哈希表中哈希桶数量很多,大大降低了锁冲突的概率,性能也大大提升。
image.png

  1. ConcurrentHashMap只对写加锁,读操作不加锁

也就是说两个线程同时修改,才会有锁冲突;两个线程都读,没有锁冲突;一个线程写,一个线程读,也没有锁冲突。
为什么一个线程读一个线程写没有锁冲突?
难道不会读到修改一半的数据吗?ConcurrentHashMap在设计的时候,考虑到这个问题,所以保证在读的时候一定是读到一整数据(要么是旧版本,要么是新版本,不会是读到一半的数据)。
并且读操作也广泛使用volatile保证读到的数据是及时的。

  1. 充分利用CAS特性

像维护元素个数就是通过CAS实现,而不是加锁;以及使用CAS实现轻量级锁/自旋锁等等。

  1. 对扩容进行特殊处理

HashTable的扩容:当put元素时,发现负载因子超过阈值就触发扩容,申请一个更大的数组,把原来旧的数据搬运到新的数组上。
上述扩容方式存在很大问题,当元素个数特别多的时候,搬运操作就会开销非常大。put操作不需要扩容时瞬间完成O(1),但是触发扩容时就可能卡很久。
ConcurrentHashMap的扩容的时候,旧的数组和新的数组是同时存在的,每次进行哈希表操作都会把旧数组上的元素搬运一部分到新数组上,直到全部搬运完,再释放旧的空间。在这个过程中如果要查询元素,旧的数组和新的数组一起查;如果要插入元素,直接往新数组上插入;如果是删除元素,直接删除不用搬运。

  1. 面试题:HashMap,HashTable,ConcurrentHahMap的区别?

先说HashMap是线程不安全的,HashTable,ConcurrentHashMap是线程安全的。
再谈ConcurrentHashMap的优化

  • 12
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

指挥部在下面

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值