目录
一、CopyOnWrite
机制
1、CopyOnWrite 原理
CopyOnWrite 简称 COW,翻译为写时复制,它是一种读写分离思想的应用。当我们对一个容器进行修改操作(添加、删除、编辑)时候,不会直接对当前容器修改,而是先将当前容器进行 Copy,复制出一个新的容器,然后在这个新的容器里进行修改元素的操作,而后面进行的读操作则继续在旧容器中读取。 修改完之后,再将原容器的引用指向新的容器,而旧的容器则进行垃圾回收。
写时复制只对修改操作进行加锁(写锁),而对于读操作则不进行加锁,这样的好处是即不会造成并发修改异常,也不会影响并发读取操作。
2、CopyOnWrite 适用的场景
从 CopyOnWrite 原理可以知道,写时复制只适合读多写少的场景,比如用户的白名单、黑名单等等。