并发聚合 CopyOnWrite
并发集合 CopyOnWrite
CopyOnWriteArrayList
内部结构比较简单;
包含了一个可重入锁:
transient final ReentrantLock lock = new ReentrantLock();
一个易变的对象类型数组。它是具体包含数据的主角,只是其内容总是在数据发生变化时,集体哗变:
private volatile transient Object[] array;
增删操作会使用Arrays.copyOf或者System.arraycopy,因此较ArrayList会慢。
查找很快,既是对内部数组的数据定位。较之ArrayList,没有校验边界,因为并发下,边界有可能发生改变。
public E get(int index) { return (E) (getArray()[index]); }
CopyOnWriteArraySet