copy-on-write容器

本文介绍了写时复制技术的工作原理及其实现方式,探讨了该技术如何提高读操作的效率,尤其是在读多写少的高并发场景中。通过将读操作设置为无锁状态,并在写操作时复制数据,使得读写可以并行执行,从而实现高效的数据访问。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

写时复制,见名知义,就是在写的时候,进行复制。
jdk中的CopyOnWriteArrayList实现了这种技术。

在高并发的读多写少的场景下,比如系统级别的信息,往往只是需要加载到内存,很少有修改的必要。在高并发场景下,虽然有读写锁的概念,但是读跟写依然是串行的。如果我们为了高效的读,可以容忍写慢一点,可以用这样一种机制,就是读的时候是无锁的,哪怕是读写同时进行,那么如果保持数据的一致性呢?我们知道,读是不改变数据的。写的时候,先将容器复制一份,然后在副本上面进行写操作。所有的读操作都在老容器上进行。当写完毕时,将原容器的引用指向副本。

可以看出,这种机制最大限度的提高了读的效率,但是明显降低了写的效率。除非是高并发场景对读的要求特别高,并且不在乎写的慢,否则不建议使用此容器。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值