[英]Using the clone method without catching CloneNotSupportedException
[英]Making a clone function without throwing CloneNotSupportedException exception in Java
作为我们作业的一部分,我们被要求用clone
方法实现一个抽象类。 该函数的框架给出:
/**
* @effects Creates and returns a copy of this.
*/
public Object clone() {
// TODO: Implement this method
}
Shape
类有两个字段:
private Point location;
private Color color;
在说明中,我们被告知该方法不会抛出CloneNotSupportedException
异常,并且还会询问它为什么会这样。 在我们在互联网上看到的所有示例中,clone方法都会抛出CloneNotSupportedException
。
您能否指出我们为什么这个克隆方法不应抛出该异常的原因。
我们编写的方法是:
/**
* @effects Creates and returns a copy of this.
*/
public Object clone() {
Shape new_shape = (Shape)super.clone();
new_shape.setColor(this.getColor());
new_shape.location = (Point)location.clone();
return new_shape;
}
它给我们一个错误的(Shape)super.clone()
部分,说:
Unhandled exception type CloneNotSupportedException
,我们应该如何创建克隆方法?
您的类应该实现Clonable接口。
您也可以使用Covariant返回类型返回Shape / Point而不是Object。 这有助于您避免不必要的类型转换。
未处理的异常类型CloneNotSupportedException
那是因为Object
的clone()
方法被定义为抛出CloneNotSupportedException
:
protected Object clone() throws CloneNotSupportedException
请参阅API doc: Object#clone()
要解决这个问题,您需要使用try/catch
块来处理它,或者通过添加throws
子句来重新定义它。
更新:
在说明中,我们被告知该方法不会抛出CloneNotSupportedException异常,并且还会询问它为什么会这样。
IMO -
Cloneable
接口时,它告诉Object
类可以克隆它。 在这种情况下, clone
方法的正确实现应该调用super.clone
方法。 现在,您可以看到它实际上是Object
类中实际生成副本的clone
方法。 因此,我们应该留下Object.clone()
来抛出CloneNotSupportedException
。 如果层次结构中的任何类未实现Cloneable
接口,它将执行此操作。 我希望这是有道理的。
即使它有点大,如果你想更多地阅读它。 它在Effective Java中有所解释。
其他实现抛出CloneNotSupportedException的原因是它是Object的现有clone()方法的一部分 。 仅仅因为定义一个方法来抛出异常并不意味着它必须这样做。 在Shape及其派生类上实现clone()方法时,不要抛出异常。
(Shape)super.clone()
抛出异常的原因是这是默认行为。 在Shape上实现clone()。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.