写时复制,见名知义,就是在写的时候,进行复制。
jdk中的CopyOnWriteArrayList实现了这种技术。
在高并发的读多写少的场景下,比如系统级别的信息,往往只是需要加载到内存,很少有修改的必要。在高并发场景下,虽然有读写锁的概念,但是读跟写依然是串行的。如果我们为了高效的读,可以容忍写慢一点,可以用这样一种机制,就是读的时候是无锁的,哪怕是读写同时进行,那么如果保持数据的一致性呢?我们知道,读是不改变数据的。写的时候,先将容器复制一份,然后在副本上面进行写操作。所有的读操作都在老容器上进行。当写完毕时,将原容器的引用指向副本。
可以看出,这种机制最大限度的提高了读的效率,但是明显降低了写的效率。除非是高并发场景对读的要求特别高,并且不在乎写的慢,否则不建议使用此容器。