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

想要产生一个新对象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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值