Object类中的clone方法 & 浅克隆和深克隆

来源:互联网 发布:庭审网络直播 编辑:程序博客网 时间:2024/04/30 11:50

想要产生一个新对象p2与原来对象p1具有相同的内容 
 最理想的方法就是调用clone方法,而不需要去先new出一个对象出来,
 然后再将p1的值赋值给p2   因为clone()方法是一个本地方法
 native方法的效率一般来说都是远高于java中的非native方法。

public class Clone {
public static void main(String[] args) throws CloneNotSupportedException {
Person p1 = new Person();
p1.setName("小强");
p1.setAge(12);
p1.setHireDay(new Date());
System.out.println(p1.getName() + ":" + p1.getAge());

Person p2 = (Person) p1.clone();
System.out.println(p2.getName() + ":" + p2.getAge());

System.out.println(p1 == p2);//false
System.out.println(p1.getHireDay() == p2.getHireDay());
//开始由于是浅clone 所以person对象的子对象hireDay没有进行clone              //true  指向同一片对内存区域
//在person类中的clone方法中对hireDay进行clone后                                           //false  指向不同区域
}
}


import java.util.Date;
public class Person implements Cloneable/*标记接口,没有任何方法,
唯一作用就是作为一个标志,用来告诉JVM某各类是否具有某个特定功能*/{
private String name;
private int age;
private Date hireDay = null;//引用类型,用来说明浅克隆和深克隆

public Date getHireDay() {
return hireDay;
}


public void setHireDay(Date hireDay) {
this.hireDay = hireDay;
}


@Override
protected Object clone() throws CloneNotSupportedException {

Person p = null;
p = (Person) super.clone();
//p.hireDay = (Date) hireDay.clone();
return p;

}

public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}

}

在Person类中想要覆盖clone方法  就要继承Cloneable接口  否则会抛出CloneNotSupportedException异常。

由于Object类中的clone方法是protected方法,在复写该方法时,需要声明为public

0 0