Copy-On-Write 是什么?
首先我讲一下什么是Copy-On-Write,顾名思义,在计算机中就是当你想要对一块内存进行修改时,我们不在原有内存块中进行写操作,而是将内存拷贝一份,在新的内存中进行写操作,写完之后呢,就将指向原来内存指针指向新的内存,原来的内存就可以被回收掉嘛!
这是一种用于程序设计中的优化策略,是一种延时懒惰策略
CopyOnWriteArrayList 避免了多线程操作List线程不安全的问题,可以在非常多的并发场景中使用到,原理就是在写的时候不对原集合进行修改,而是重新复制一份,修改完之后,再移动指针。
写时复制,加锁
CopyOnWriteArrayList优缺点
缺点:
1、耗内存(集合复制)
2、实时性不高
优点:
1、数据一致性完整,为什么?因为写加锁了,并发数据不会乱
2、解决了像ArrayList、Vector这种集合多线程遍历迭代问题,记住,Vector虽然线程安全,只不过是加了synchronized关键字,迭代问题完全没有解决!
CopyOnWriteArrayList使用场景
1、读多写少(白名单,黑名单,商品类目的访问和更新场景),为什么?因为写的时候会复制新集合
2、集合不大,为什么?因为写的时候会复制新集合
实时性要求不高,为什么,因为有可能会读取到旧的集合数据