CopyOnWriteArrayList使⽤了⼀种叫写时复制的⽅法,当有新元素添加到CopyOnWriteArrayList时, 先从原有的数组中拷⻉⼀份出来,然后在新的数组做写操作,写完之后,再将原来的数组引⽤指向到新 数组。
CopyOnWriteArrayList 的整个add操作都是在锁的保护下进⾏的。 这样做是为了避免在多线程并 发add的时候,复制出多个副本出来,把数据搞乱了,导致最终的数组数据不是我们期望的。
由于所有的写操作都是在新数组进⾏的,这个时候如果有线程并发的写,则通过锁来控制,如果有线程 并发的读,则分⼏种情况: 1、如果写操作未完成,那么直接读取原数组的数据; 2、如果写操作完成,但是引⽤还未指向新数组,那么也是读取原数组数据; 3、如果写操作完成,并且引⽤已经指向了新的数组,那么直接从新数组中读取数据。 可⻅, CopyOnWriteArrayList 的读操作是可以不⽤加锁的。