CopyOnWrite机制

什么是CopyOnWrite容器

CopyOnWrite是一种在并发场景下常用的设计思想——写入时复制思想。写入时复制思想是指:当有多个调用者同时去请求一个资源数据的时候,有一个调用者需要对当前数据源进行修改,此时系统将会复制一个当前数据源的副本给调用者修改。也就是说,当我们往一个容器中添加元素的时候,不直接往容器中添加,而是将当前容器进行copy,复制出来一个新的容器,然后向新容器中添加我们需要的元素,最后将原容器的引用指向新容器。

这样我们就可以在并发的场景下对容器进行"读操作"而不需要"加锁",从而达到读写分离的目的。JDK提供了两个使用CopyOnWrite机制实现的并发容器CopyOnWriteArrayList和CopyOnWriteArraySet 。

 

CopyOnWriteArrayList

缺点

内存占用问题:因为CopyOnWrite的写时复制机制,所以在进行写操作的时候,内存里会同时驻扎两个对象的内存,旧的对象和新写入的对象。如果这些对象占用的内存比较大,很有可能造成频繁的Yong GC和Full GC。

数据一致性问题:CopyOnWrite容器只能保证数据的最终一致性,不能保证数据的实时一致性。(当执行add或remove操作没完成时,get获取的仍然是旧数组的元素)

 

读取操作

下面的代码展示了有关读取的实现。可以发现,读取代码没有任何同步控制和所查找,因为内部数组array不会发生修改,只会被另一个array替换。

    pri
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值