想要产生一个新对象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 指向不同区域
}
}
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