Из CopyOnWriteArrayList.java метод добавления выглядит следующим образом:
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();
}
}
Нетрудно понять, что операция добавления должна блокироваться, меня смущает то, что она копирует старые данные в новый массив и отказывается от предыдущего. между тем метод get выглядит следующим образом:
public E get(int index) {
return (E)(getArray()[index]);
}
Без блокировки в методе get. Я нахожу некоторые объяснения, некоторые говорят, что копирование в новый массив может избежать добавления и получения метода, работающего с одним и тем же массивом. Моя проблема в том, почему два потока не могут одновременно читать и писать?