java super.clone 实现Cloneable接口
首先,如果允许本来被克隆,需要实现 实现Cloneable接口
并且重写clone方法,且方法最好为public,这样方便别人调用
其中:super.clone并不是简单的说成是调用父类的clone方法,这样的话你很难想通,为什么调用父类的clone,对吧?
因为Object的clone方法使用了RTTI(运行时类型识别)机制,可以动态的找到目前正在调用clone方法的那个引用,并找到它指向的对象,然后根据这个对象的大小去申请内存空间,然后进行bitwise(逐位)的复制, 将该对象的内存空间完全复制到新的空间中去,
从而达到克隆的目的.
即,谁调用clone方法,就克隆这引用指向的对象
子类没有clone方法,使用this.clone()则直接异常,,因为是子类继承Object的
比如你有一个Student类实现了Cloneable接口,重写了clone方法,但是重写的clone方法里的执行super.clone,并不是说和自身无关,
例如: Student stu=new student();
Student stu1=(Student)stu.clone();
当执行stu.clone();时候,虽然clone方法里面执行的是super.clone(),但是Object的clone方法会寻找当前正在调用clone方法的那个引用,这里这个引用就是stu,然后自动的去找stu指向的对象,然后进行逐位赋值,从而达到克隆的目的,
还有继承的时候,A类实现了Cloneable接口,重写了了clone方法,那继承A类的类就不必实现Cloneable接口以及重写clone方法了,因为A类已经这么做了。而当子类调用clone方法的时候,是根据调用clone方法的当前引用去克隆的,
还是那句话,谁调用clone方法,就克隆当前引用指向的对象
ps:网上都是互相抄的,我用自己理解翻译解释一下,呵呵