集合的线程安全

本文介绍了Java中集合的线程安全,重点讲解了CopyOnWriteArrayList的读写不互斥机制以及ConcurrentHashMap的高效实现。CopyOnWriteArrayList通过在写时复制数组来保证线程安全,而ConcurrentHashMap使用分段锁技术,提高了并发访问效率,降低了锁的粒度。
摘要由CSDN通过智能技术生成

 

CopyOnWriteArrayList

写入时先Copy一个容器副本,再添加新元素,最后替换引用。

1、如果写操作未完成,那么直接读取原数组的数据;

2、如果写操作完成,但是引用还未指向新数组,那么也是读取原数组数据;

3、如果写操作完成,并且引用已经指向了新的数组,那么直接从新数组中读取数据。 

这样子就读写不互斥,效率很高,此时是写有锁,读没锁。优于读写锁,因为读写锁是互斥的

 

 ConcurrentHashMap

一、什么是ConcurrentHashMap?为什么要引ConcurrentHashMap?

    1、HashMap线程是不安全,它

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值