并发集合 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

你可能感兴趣的:(数据结构)