2007年11月23日 14:48:51
JAVA基础之 clone 详解(一)认识clone
|
Clone基本知识储备 Copy code
这段源码的@exception部分的描述内容证实了上文关于clone对象特性论断的正确性。它明确指出对象类必须支持Cloneable接口,否则即使派生类覆盖了Object#clone()方法,也同样会抛出CloneNotSupportedException这个异常。关于覆盖clone()方法,后续文章将会用专门篇幅进行比较详细的分析. clone的实现 1.实现Cloneable接口 我们知道一个类若要具备clone功能,就必须实现Cloneable接口。做到这一步,clone功能已经基本实现了。Clone功能对我们来说,最主要的还是要能够使用它。那么我们如何才能使用clone功能呢?答案是覆盖Object#clone()方法。 2. 覆盖Object#clone()方法 为什么需要覆盖Object#clone()方法?JDK中Object# clone()方法的原型是: protected native Object clone() throws CloneNotSupportedException; 是否注意到,这里clone()方法修饰符是protected,而不是public。这种访问的不可见性使得我们对Object#clone()方法不可见。相信读者已明白为什么要覆盖Object#clone()方法。而且,覆盖的方法的修饰符必须是public,如果还保留为protected,覆盖将变得没有实际意义。下面举一个具有clone功能的简单的例子 /* * 具有clone功能的类的例子 */ public class CloneableObjExample implements Cloneable { private String name = null; private int score = 0; /** * NOTE: 将protected 修饰符更改为public * @see java.lang.Object#clone() */ public/*protected*/ Object clone()throws CloneNotSupportedException{ //call父类的clone方法 Object result = super.clone(); //TODO: 定制clone数据 return result; } } 3.定制clone 至此,clone已经真相大白。Clone的对象我们可以对其进行定制。还就上面的例子来说。下面的方法对功能做了一定的增强: public/*protected*/ Object clone() throws CloneNotSupportedException { // call父类的clone方法 CloneableObjExample result = (CloneableObjExample)super.clone(); //TODO: 定制clone数据 //虽然”clone”了,但还可以做点调整 result.name = “New Name”; result.score = 90; return result; } 本篇介绍了如何实现clone。接下来的篇幅将就纵深clone等clone的高级特性进行分析。 |
一共有 0 条评论