原型模式(克隆模式):浅谈浅克隆与深克隆

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_18975791/article/details/83176965

克隆是什么?它的产生背景?

当new的对象是多例的时候,new对象将会不断占据内存。特别是消耗内存的大对象,比如数据库连接等。平时运用的不多,只在spring等容器有见过,此处不多赘述,了解即可。

浅克隆与深克隆是什么意思?通过案例逐步探讨。

public class Star implements Cloneable,Serializable{
    private String name;
    private Date birthday;
    
    public Star(){}
    public Star(String name, Date birthday) {
        super();
        this.name = name;
        this.birthday = birthday;
    }

    //实现浅克隆
    @Override
    protected Object clone() throws CloneNotSupportedException {
        return super.clone();
    }
    
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public Date getBirthday() {
        return birthday;
    }
    public void setBirthday(Date birthday) {
        this.birthday = birthday;
    }

}

明星实体类-浅克隆
public class Client {
    public static void main(String[] args) throws CloneNotSupportedException {
        Date date=new Date(1346545646556465131L);
        //new一个明星:杨洋
        Star  yangYang=new Star("杨洋",date);
        System.out.println(yangYang);
        System.out.println(yangYang.getName());
        System.out.println(yangYang.getBirthday());
        
        date.setTime(4685456456456465465L);
        System.out.println(yangYang.getBirthday());
        
        //克隆杨洋:满足你当明星的梦
        Star me=(Star) yangYang.clone();
        System.out.println(me);
        me.setName("周杰伦");
        System.out.println(me.getName());
        System.out.println(me.getBirthday());    
    }
}

问题:我们发现,当date改变的时候,克隆对象的date也随之改变。这个不难理解,因为原型对象改变,克隆对象也随之改变,克隆对象只是克隆了star对象,并没有去克隆star对象中的birthday对象。

结论:浅克隆就是克隆对象直接引用原型对象。

public class Star2 implements Cloneable{
    private String name;
    private Date birthday;
    
    public Star2(){}
    public Star2(String name, Date birthday) {
        super();
        this.name = name;
        this.birthday = birthday;
    }
    //实现深克隆
    @Override
    protected Object clone() throws CloneNotSupportedException {
        Object obj= super.clone();
        
        Star2 s=(Star2)obj;
        s.birthday=(Date) this.birthday.clone();
        return obj;
    }
    
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public Date getBirthday() {
        return birthday;
    }
    public void setBirthday(Date birthday) {
        this.birthday = birthday;
    }

}

明星实体类-深克隆
public class Client2 {
    public static void main(String[] args) throws CloneNotSupportedException {
        Date date=new Date(1346545646556465131L);
        //new一个明星:杨洋
        Star2  yangYang=new Star2("杨洋",date);
        Star2 me=(Star2) yangYang.clone();//深克隆里面的birthday对象是一个新对象
        
        System.out.println(yangYang);
        System.out.println(yangYang.getName());
        System.out.println(yangYang.getBirthday());
        
        date.setTime(4685456456456465465L);
        System.out.println(yangYang.getBirthday());
        
        
        System.out.println(me);
        me.setName("周杰伦");
        System.out.println(me.getName());
        System.out.println(me.getBirthday());        
    }
}

 

问题:我们发现,当date改变的时候,克隆对象的bitthday并没有随之改变。通过实体类可知,当克隆对象的时候,随之也去克隆了实体类里面的引用对象,即克隆对象的birthday是一个new的对象。

结论:深克隆就是递归克隆出原型对象里的所有引用对象。

猜你喜欢

转载自blog.csdn.net/qq_18975791/article/details/83176965