clone方法用于制作深层副本.确保您了解深层副本和浅层副本之间的区别.在您的情况下,复制构造函数可能是您想要的模式.但是,在某些情况下,您不能使用此模式,例如,因为您正在继承类X,而您无权访问所需的X的构造函数.如果X正确覆盖了其clone方法(如有必要),则可以通过以下方式进行复制:
class Y extends X implements Cloneable {
private SomeType field; // a field that needs copying in order to get a deep copy of a Y object
...
@Override
public Y clone() {
final Y clone;
try {
clone = (Y) super.clone();
}
catch (CloneNotSupportedException ex) {
throw new RuntimeException("superclass messed up", ex);
}
clone.field = this.field.clone();
return clone;
}
}
通常,覆盖克隆方法时:
>使返回类型更具体
>从调用super.clone()开始
>当您知道clone()也可用于任何子类时(请注意clone-pattern的弱点;如果可能,请使类为final),不要包含throws子句
>保留不可变字段和原始字段,但是在调用super.clone()之后手动克隆可变对象字段(克隆模式的另一个弱点,因为这些字段不能定型)
Object的clone()方法(当所有超类都遵守合同时最终将被调用)进行浅表复制并照顾新对象的正确运行时类型.注意在整个过程中如何不调用构造函数.
如果您希望能够在实例上调用clone(),则实现Cloneable接口并使该方法公开.如果您不想在实例上调用它,但确实要确保子类可以调用它们的super.clone()并获取所需的东西,那么就不要实现Cloneable并在您的情况下将方法保持受保护的状态.超类尚未宣布为公开.
克隆模式很困难,并且有很多陷阱.确保这是您所需要的.考虑复制构造函数或静态工厂方法.