В книге Блоха «Эффективная Java», 2-е издание, Пункт 11: Разумное переопределение клона содержит следующий пример:
class Stack {
private Object[] elements;
private int size = 0;
private static final int DEFAULT_INITIAL_CAPACITY = 16;
public Stack() {
this.elements = new Object[DEFAULT_INITIAL_CAPACITY];
}
public void push(Object e) {
ensureCapacity();
elements[size++] = e;
}
public Object pop() {
if (size == 0)
throw new EmptyStackException();
Object result = elements[--size];
elements[size] = null; // Eliminate obsolete reference
return result;
}
// Ensure space for at least one more element.
private void ensureCapacity() {
if (elements.length == size)
elements = Arrays.copyOf(elements, 2 * size + 1);
}
@Override public Stack clone() {
try {
Stack result = (Stack) super.clone();
result.elements = elements.clone();
return result;
} catch (CloneNotSupportedException e) {
throw new AssertionError();
}
}
}
Как видите, в методе clone()
создается новый объект типа Stack
с именем result
. Впоследствии мы клонируем result.elements
, несмотря на то, что класс Stack
определяет elements
как закрытый член. Что происходит и почему это разрешено?
Stack
, так по какой причине мы не можем этого сделать? - person Phạm Lam   schedule 22.06.2017