如何通过序列化实现深拷贝

先说说Java的浅、深拷贝?

浅拷贝:只复制一个对象,对象内部存在的指向其他对象数组或者引用则不复制。

深拷贝:对象,对象内部的引用均复制


java.lang.Object的clone()方法默认是返回一个浅拷贝对象。因此如果要用clone()方法实现一个深拷贝,我们必须对每个对象的clone()方法进行特别实现。当对象层次复杂的时候,这样做不但困难而且浪费时间和容易出现错误,特别有时候你不但需要深拷贝同时你也对这个对象进行浅拷贝的时候,你会发现写这个clone()方法真不是一个好的解决方案。

那么除了clone()方法,我们还可以怎么实现呢?答案是序列化,实现步骤和思路是把要拷贝的对象输出成byte array,然后再利用ObjectInputStream转换出新的对象。就可以完成深拷贝。


下面是实现代码:


//把对象先写到字节数组中,然后从字节数组中读对象。

public static Object copy(Object oldObj) {  

    Object obj =null;  

    try {  

        // Writethe object out to a byte array  

       ByteArrayOutputStream bos = new ByteArrayOutputStream();  

        ObjectOutputStream out = new ObjectOutputStream(bos);  

       out.writeObject(oldObj);  

       out.flush();  

       out.close();  

 

        //Retrieve an input stream from the byte array and read  

        // acopy of the object back in.  

       ByteArrayInputStream bis = newByteArrayInputStream(bos.toByteArray());   

       ObjectInputStream in = new ObjectInputStream(bis);  

        obj =in.readObject();  

    } catch(IOException e) {  

       e.printStackTrace();  

    } catch(ClassNotFoundException cnfe) {  

       cnfe.printStackTrace();  

    }  

    returnobj;  

}  




Java中,可以使用序列化实现深拷贝深拷贝是指创建一个全新的对象,将原始对象的所有属性值复制到新对象中。以下是一个简单的示例代码,演示如何通过序列化实现深拷贝: ```java import java.io.*; class MyClass implements Serializable { private int value; public MyClass(int value) { this.value = value; } public int getValue() { return value; } } public class DeepCopyExample { public static void main(String[] args) throws IOException, ClassNotFoundException { // 创建原始对象 MyClass originalObj = new MyClass(10); // 将原始对象序列化到字节数组输出流中 ByteArrayOutputStream baos = new ByteArrayOutputStream(); ObjectOutputStream oos = new ObjectOutputStream(baos); oos.writeObject(originalObj); oos.close(); // 从字节数组输入流中反序列化出新的对象 ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray()); ObjectInputStream ois = new ObjectInputStream(bais); MyClass clonedObj = (MyClass) ois.readObject(); ois.close(); // 修改原始对象的值 originalObj.setValue(20); // 输出结果 System.out.println("Original value: " + originalObj.getValue()); System.out.println("Cloned value: " + clonedObj.getValue()); } } ``` 在上面的示例中,我们定义了一个名为`MyClass`的类,它实现了`Serializable`接口。然后,我们创建了一个原始对象`originalObj`,并将其序列化到字节数组输出流中。接着,我们通过反序列化从字节数组输入流中创建了一个新的对象`clonedObj`。最后,我们修改了原始对象的值,并输出了原始对象和克隆对象的值。 通过这种方式,我们实现深拷贝,因为`clonedObj`是一个全新的对象,它的属性值与原始对象`originalObj`的属性值相同,但是它们之间没有引用关系。这意味着对其中一个对象的修改不会影响另一个对象
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值