CopyOnWriteArray

本文深入解析了CopyOnWriteArrayList的实现原理,包括其线程安全的add、set和contains方法的具体实现细节。CopyOnWriteArrayList通过复制底层数组并在新副本上进行修改来确保线程安全性,避免了迭代时的并发修改异常。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class CopyOnWriteArrayList<E>
    implements List<E>, RandomAccess, Cloneable, java.io.Serializable{
	
	private transient volatile Object[] array;
	
	public boolean contains(Object o) {
        Object[] elements = getArray();
        return indexOf(o, elements, 0, elements.length) >= 0;
    }
    
    
	public boolean add(E e) {
        	final ReentrantLock lock = this.lock;
       		lock.lock();
        	try {
            	Object[] elements = getArray();
            	int len = elements.length;
            	Object[] newElements = Arrays.copyOf(elements, len + 1);
            	newElements[len] = e;
            	setArray(newElements);
           	 	return true;
       	 	} finally {
            	lock.unlock();
        	}
    }
    
	public E set(int index, E element) {
        final ReentrantLock lock = this.lock;
        lock.lock();
        try {
            Object[] elements = getArray();
            E oldValue = get(elements, index);

            if (oldValue != element) {
                int len = elements.length;
                Object[] newElements = Arrays.copyOf(elements, len);
                newElements[index] = element;
                setArray(newElements);
            } else {
                // Not quite a no-op; ensures volatile write semantics
                setArray(elements);
            }
            return oldValue;
        } finally {
            lock.unlock();
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值