读书人

并发聚合 CopyOnWrite

发布时间: 2012-12-26 14:39:28 作者: rapoo

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

读书人网 >编程

热点推荐