java 深拷贝

在Map中提供的一个putAll方法,可以部分解决无法深拷贝这个问题,(为什么是部分呢?因为putAll方法只能对基本数据类型进行深复制,对于对象类型完全也是无力),因此急需一个好的解决方案来进行对象的深复制
有一个方法是,使用序列化Serializable这个接口可以完成深拷贝的操作,但遗憾的是Map对象并没有实现Serializable接口,不能直接对接口进行深复制操作。

但是作为Map的子类,HashMap实现了Serialization,因此可以通过以下的方式实现深复制。

public static <T extends Serializable> T clone(T obj) {
     T clonedObj = null;
     try {
         ByteArrayOutputStream baos = new ByteArrayOutputStream();
         ObjectOutputStream oos = new ObjectOutputStream(baos);
         oos.writeObject(obj);
         oos.close();

         ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray());
         ObjectInputStream ois = new ObjectInputStream(bais);
         clonedObj = (T) ois.readObject();
         ois.close();
     } catch (Exception e) {
         e.printStackTrace();
     }
    return clonedObj;
 }
Java深拷贝是创建对象副本的过程,同时复制其所有嵌套对象和引用类型的字段,正确实现深拷贝对于确保数据一致性和避免副作用至关重要[^1]。以下是几种常见的Java深拷贝实现方法及原理: ### 序列化和反序列化 原理:将对象转换为字节流,再从字节流中反序列化出一个新的对象。因为字节流是对象的完整副本,所以反序列化得到的对象和原对象相互独立。 示例代码: ```java import java.io.*; class DeepCopyObject implements Serializable { private int value; public DeepCopyObject(int value) { this.value = value; } public int getValue() { return value; } public static DeepCopyObject deepCopy(DeepCopyObject original) { DeepCopyObject copy = null; try { ByteArrayOutputStream bos = new ByteArrayOutputStream(); ObjectOutputStream oos = new ObjectOutputStream(bos); oos.writeObject(original); ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray()); ObjectInputStream ois = new ObjectInputStream(bis); copy = (DeepCopyObject) ois.readObject(); } catch (IOException | ClassNotFoundException e) { e.printStackTrace(); } return copy; } } ``` ### 手动递归复制 原理:通过编写代码手动遍历对象的所有字段,对于基本数据类型直接复制值,对于引用类型递归调用复制方法创建新的对象。 示例代码: ```java class Person { private String name; private Address address; public Person(String name, Address address) { this.name = name; this.address = address; } public Person deepCopy() { Address newAddress = new Address(address.getStreet(), address.getCity()); return new Person(this.name, newAddress); } // Getters and setters } class Address { private String street; private String city; public Address(String street, String city) { this.street = street; this.city = city; } // Getters and setters } ``` ### 使用第三方库 原理:借助第三方库如Apache Commons Lang中的`SerializationUtils`类,其内部实现了序列化和反序列化的逻辑。 示例代码: ```java import org.apache.commons.lang3.SerializationUtils; class DeepCopyExample { public static void main(String[] args) { DeepCopyObject original = new DeepCopyObject(10); DeepCopyObject copy = (DeepCopyObject) SerializationUtils.clone(original); } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值