多线程中的Copy-On-Write

  1. Copy-On-Write 容器 两种 CopyOnWriteArrayList 和CopyOnWriteArraySet 写时复制的容器 向一个容器添加元素时先将此容器复制,然后向复制后的容器添加元素,这样原容器不需要加任何锁,可以实现同步读操作,然后添加完元素后将引用指向新的copy触的容器。也就是所说的读写分离机制
  2. 解读:当线程一想要对CopyOnWRite容器进行写操作时,CopyOnWrite容器会复制一份容器出来,然后让线程一去修改容器的副本,而不是修改原容器,这时指针依然指在原容器上,写的过程中如果有多个线程想要读取容器中的数据,那么这些线程会去指针指向的容器中去读取数据。不用加任何锁,这样无论有多少个线程同时访问原容器都是可以的,效率当然就很高了。但是肯定有人会有疑问,就是如果同一时间有多个请求过来要修改容器内的数据,会怎么样?这种情况下,当第一个写请求被容器收到后,容器复制出一个副本出来,线程一去这个副本修改数据,其它线程也要修改容器数据,那就只能在副本容器外排队等候,因为容器的写操作是加锁的。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值