快速业务通道

JAVA中的指针,引用及对象的clone - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-21
()方法。还有一点要考虑的是为了让其它类能调用这个clone类的clone()方法,重载之后要把clone()方法的属性设置为public。

那么clone类为什么还要实现Cloneable接口呢?稍微注意一下,Cloneable接口是不包含任何方法的!其实这个接口仅仅是一个标志,而且这个标志也仅仅是针对Object类中clone()方法的,如果clone类没有实现Cloneable接口,并调用了Object的clone()方法(也就是调用了super.Clone()方法),那么Object的clone()方法就会抛出CloneNotSupportedException异常。

以上是clone的最基本的步骤,想要完成一个成功的clone,还要了解什么是"影子clone"和"深度clone"。

JAVA中的指针,引用及对象的clone(4)

时间:2011-01-06 IBM 倪大鹏

什么是影子clone?

下面的例子包含三个类UnCloneA,CloneB,CloneMain。CloneB类包含了一个UnCloneA的实例和一个int类型变量,并且重载clone()方法。CloneMain类初始化UnCloneA类的一个实例b1,然后调用clone()方法生成了一个b1的拷贝b2。最后考察一下b1和b2的输出:

package clone; class UnCloneA {    private int i;    public UnCloneA(int ii) { i = ii; }    public void doubleValue() { i *= 2; }    public String toString() {      return Integer.toString(i);    } } class CloneB implements Cloneable{    public int aInt;    public UnCloneA unCA = new UnCloneA(111);    public Object clone(){      CloneB o = null;      try{        o = (CloneB)super.clone();      }catch(CloneNotSupportedException e){        e.printStackTrace();      }      return o;    } } public class CloneMain {    public static void main(String[] a){      CloneB b1 = new CloneB();      b1.aInt = 11;      System.out.println("before clone,b1.aInt = "+ b1.aInt);      System.out.println("before clone,b1.unCA = "+ b1.unCA);               CloneB b2 = (CloneB)b1.clone();      b2.aInt = 22;      b2.unCA.doubleValue();      System.out.println("=================================");      System.out.println("after clone,b1.aInt = "+ b1.aInt);      System.out.println("after clone,b1.unCA = "+ b1.unCA);      System.out.println("=================================");      System.out.println("after clone,b2.aInt = "+ b2.aInt);      System.out.println("after clone,b2.unCA = "+ b2.unCA);    } } /** RUN RESULT: before clone,b1.aInt = 11 before clone,b1.unCA = 111 ================================= after clone,b1.aInt = 11 after clone,b1.unCA = 222 ================================= after clone,b2.aInt = 22 after clone,b2.unCA = 222 */

输出的结果说明int类型的变量aInt和UnCloneA的实例对象unCA的clone结果不一致,int类型是真正的被clone了,因为改变了b2中的aInt变量,对b1的aInt没有产生影响,也就是说,b2.aInt与b1.aInt已经占据了不同的内存空间,b2.aInt是b1.aInt的一个真正拷贝。相反,对b2.unCA的改变同时改变了b1.unCA,很明显,b2.unCA和b1.unCA是仅仅指向同一个对象的不同引用!从中可以看出,调用Object类中clone()方法产生的效果是:先在内存中开辟一块和原始对象一样的空间,然后原样拷贝原始对象中的内容。对基本数据类型,这样的操作是没有问题的

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号