java 如何实现对象克隆_Java对象克隆

Java不提供克隆(复制)对象的自动机制。克隆对象意味着逐位复制对象的内容。要支持克隆操作,请在类中实现clone()方法。Object类中的clone()方法的声明如下:

protected Object clone() throws CloneNotSupportedException

clone()方法声明为protected。 因此,不能从客户端代码调用它。以下代码无效:

Object obj = new Object();

Object clone = obj.clone(); // Error. Cannot access protected clone() method

需要在类中声明clone()方法为public来克隆类的对象。

它的返回类型是Object。 这意味着将需要使用clone()方法转换返回值。

假设MyClass是可克隆的。 克隆代码将如下所示

MyClass mc = new MyClass();

MyClass clone = (MyClass)mc.clone(); // Need to use a cast

Object类中的clone()方法会抛出CloneNotSupportedException。要调用clone()方法,需要将调用放在try-catch块中,或者重新抛出异常。

示例

以下代码显示了如何实现克隆方法。

class MyClass implements Cloneable {

private double value;

public MyClass(double value) {

this.value = value;

}

public void setValue(double value) {

this.value = value;

}

public double getValue() {

return this.value;

}

public Object clone() {

MyClass copy = null;

try {

copy = (MyClass) super.clone();

} catch (CloneNotSupportedException e) {

e.printStackTrace();

}

return copy;

}

}

public class Main {

public static void main(String[] args) {

MyClass dh = new MyClass(100.00);

MyClass dhClone = (MyClass) dh.clone();

System.out.println("Original:" + dh.getValue());

System.out.println("Clone :" + dhClone.getValue());

dh.setValue(100.00);

dhClone.setValue(200.00);

System.out.println("Original:" + dh.getValue());

System.out.println("Clone :" + dhClone.getValue());

}

}

上面的代码生成以下结果。

Original:100.0

Clone :100.0

Original:100.0

Clone :200.0

实例-2

以下代码不从clone()方法返回对象类型,该方法仅在Java5或更高版本中编译。

class MyClass implements Cloneable {

public MyClass clone() {

Object copy = null;

return (MyClass)copy;

}

}

下面的代码展示了如何做浅克隆。

class MyClass implements Cloneable {

private double value;

public MyClass(double value) {

this.value = value;

}

public void setValue(double value) {

this.value = value;

}

public double getValue() {

return this.value;

}

public Object clone() {

MyClass copy = null;

try {

copy = (MyClass) super.clone();

} catch (CloneNotSupportedException e) {

e.printStackTrace();

}

return copy;

}

}

class ShallowClone implements Cloneable {

private MyClass holder = new MyClass(0.0);

public ShallowClone(double value) {

this.holder.setValue(value);

}

public void setValue(double value) {

this.holder.setValue(value);

}

public double getValue() {

return this.holder.getValue();

}

public Object clone() {

ShallowClone copy = null;

try {

copy = (ShallowClone) super.clone();

} catch (CloneNotSupportedException e) {

e.printStackTrace();

}

return copy;

}

}

public class Main {

public static void main(String[] args) {

ShallowClone sc = new ShallowClone(100.00);

ShallowClone scClone = (ShallowClone) sc.clone();

System.out.println("Original:" + sc.getValue());

System.out.println("Clone :" + scClone.getValue());

sc.setValue(200.00);

System.out.println("Original:" + sc.getValue());

System.out.println("Clone :" + scClone.getValue());

}

}

上面的代码生成以下结果。

Original:100.0

Clone :100.0

Original:200.0

Clone :200.0

实例-3

ShallowClone类的clone()方法中的代码与MyClass类的clone()方法相同。当ShallowClone类使用super.clone()调用Object类的clone()方法时,它会接收自身的浅拷贝。也就是说,它与其克隆共享其实例变量中使用的DoubleHolder对象。

在深克隆中,需要克隆对象的所有引用实例变量。

class MyClass implements Cloneable {

private double value;

public MyClass(double value) {

this.value = value;

}

public void setValue(double value) {

this.value = value;

}

public double getValue() {

return this.value;

}

public Object clone() {

MyClass copy = null;

try {

copy = (MyClass) super.clone();

} catch (CloneNotSupportedException e) {

e.printStackTrace();

}

return copy;

}

}

class DeepClone implements Cloneable {

private MyClass holder = new MyClass(0.0);

public DeepClone(double value) {

this.holder.setValue(value);

}

public void setValue(double value) {

this.holder.setValue(value);

}

public double getValue() {

return this.holder.getValue();

}

public Object clone() {

DeepClone copy = null;

try {

copy = (DeepClone) super.clone();

copy.holder = (MyClass) this.holder.clone();

} catch (CloneNotSupportedException e) {

e.printStackTrace();

}

return copy;

}

}

public class Main {

public static void main(String[] args) {

DeepClone sc = new DeepClone(100.00);

DeepClone scClone = (DeepClone) sc.clone();

System.out.println("Original:" + sc.getValue());

System.out.println("Clone :" + scClone.getValue());

sc.setValue(200.00);

System.out.println("Original:" + sc.getValue());

System.out.println("Clone :" + scClone.getValue());

}

}

执行上面的代码,将生成以下结果 -

Original:100.0

Clone :100.0

Original:200.0

Clone :100.0

¥ 我要打赏

纠错/补充

收藏

加QQ群啦,易百教程官方技术学习群

注意:建议每个人选自己的技术方向加群,同一个QQ最多限加 3 个群。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值