Builder реализует Cloneable и overrides clone(), а вместо копирования каждого поля строителя неизменяемый класс хранит частный клон строителя. Это упрощает возврат нового конструктора и создание слегка измененных копий неизменяемого экземпляра.Является ли это допустимой реализацией Java неизменяемого класса и шаблона Builder?
Таким образом, я могу пойти
MyImmutable i1 = new MyImmutable.Builder().foo(1).bar(2).build();
MyImmutable i2 = i1.builder().foo(3).build();
Cloneable интерфейс называется несколько нарушена, но все это нарушает хорошее кодирование практики Java, есть какие-то проблемы с этой конструкции?
final class MyImmutable {
public int foo() { return builder.foo; }
public int bar() { return builder.bar; }
public Builder builder() { return builder.clone(); }
public static final class Builder implements Cloneable {
public Builder foo(int val) { foo = val; return this; }
public Builder bar(int val) { bar = val; return this; }
public MyImmutable build() { return new MyImmutable(this.clone()); }
private int foo = 0;
private int bar = 0;
@Override public Builder clone() { try { return (Builder)super.clone(); } catch(CloneNotSupportedException e) { throw new AssertionError(); } }
}
private MyImmutable(Builder builder) { this.builder = builder; }
private final Builder builder;
}
Я пытался вырезать несколько углов и не копировать поля явно. Метод «basedOn» действительно ясен, но мне потребуется копировать поля (снова). Возможно, я слишком ленив. – Aksel
Отличное предложение метода basedOn :) – troig