Java对象克隆(clone)深克隆及浅克隆的区别

要实现对象的克隆,必须满足一下两个条件:

1、实现Cloneable接口;

2、重新定义clone方法,并指定public访问修饰符。

class Vehicle implements Cloneable  //浅克隆

{

    public Vehicle clone() throws CloneNotSupportedException

    {

        return (Vehicle) super.clone();

    }

}

当为一个引用了对象的变量建立副本时,原变量和副本都是同一个对象的引用,这说明,任何一个变量改变都会影响另一个变量。

Vehicle original = new Vehicle();

Vehicle copy = original;

copy.engine(11) //当设置copy的engine属性的时候,original变量的engine属性也会随着改变。


如果希望copy是一个新的对象,它的初始状态和original相同,但之后各自会有不同的状态,这种情况下就可以使用clone方法。

Vehicle original = new Vehicle();

Vehicle copy = original.clone();

copy.engine(11)//当设置copy的engine属性的时候,original变量的engine属性不会改变。


此种克隆模式为浅克隆,如果对象中的所有数据域都是数值或其他基本类型,拷贝这些域是没有任何问题,但如果对象包含子对象的引用,拷贝域就会得到相同子对象的另一个引用,这样原对象和克隆对象仍然会共享一些信息。即在现有Vehicle对象添加一个新的数据域public Driver driver,再使用浅克隆时,driver变量还是会引用同一个对象。


那么此时,如果想让数据域不共享信息,就要用到深克隆

class Vehicle implements Cloneable

{

    public int engine;

    public Driver driver;   //对象;

    public Vehicle clone() throws CloneNotSupportedException

    {

        Vehicle cloned = (Vehicle) super.clone();

        cloned.driver = (Driver) driver.clone();

        return cloned;

    }

}


此文是小编参考《Java核心技术 卷 I》第六章第二节对象克隆 整理而成。

猜你喜欢

转载自blog.csdn.net/qq_33696345/article/details/80277275