深拷贝需复制对象及所引用的所有对象,Java中可通过序列化、重写clone方法、构造函数或第三方库实现。序列化法通用,要求类实现Serializable;clone方法需手动深拷贝每个引用字段;构造函数法直观可控;Gson等库利用JSON转换,适用于可序列化场景。关键在于确保各层级对象独立,避免引用共享。

在Java中实现对象的深拷贝,关键在于复制对象本身以及它所引用的所有对象,而不是仅仅复制引用。浅拷贝会导致原对象和副本共享内部对象,修改其中一个会影响另一个。深拷贝则确保两者完全独立。
这是最常见且有效的方法之一,适用于可序列化的类。
说明: Java 的序列化机制可以将对象及其引用的对象完整地写入字节流,再读取出来就能得到一个全新的对象树。步骤如下:
示例代码:
立即学习“Java免费学习笔记(深入)”;
public static <T extends Serializable> T deepCopy(T obj) {
try {
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectOutputStream oos = new ObjectOutputStream(bos);
oos.writeObject(obj);
oos.flush();
ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray());
ObjectInputStream ois = new ObjectInputStream(bis);
return (T) ois.readObject();
} catch (Exception e) {
throw new RuntimeException("深拷贝失败", e);
}
}
只要对象结构中的所有对象都支持序列化,这个方法就能完整复制整个对象图。
利用 Object 的 clone() 方法,但必须手动处理每个引用类型的字段。
注意: 默认的 clone() 是浅拷贝,必须对每个引用类型字段单独进行深拷贝操作。例如:
public class Person implements Cloneable {
private String name;
private Address address; // 引用类型
@Override
public Person clone() {
try {
Person cloned = (Person) super.clone();
// 对引用对象也进行深拷贝
cloned.address = this.address.clone();
return cloned;
} catch (CloneNotSupportedException e) {
throw new RuntimeException(e);
}
}
}
这种方式要求每个嵌套对象也都正确实现了 clone(),否则仍可能残留引用共享。
通过定义一个接受原对象的构造函数来创建副本。
例如:
public Person(Person other) {
this.name = other.name;
this.address = new Address(other.address); // 调用 Address 的拷贝构造
}
这种方法清晰可控,适合结构简单的对象。只要在构造过程中对每个引用字段都新建实例,就能实现深拷贝。
利用 JSON 序列化工具进行深拷贝。
示例(使用 Gson):
Gson gson = new Gson(); String json = gson.toJson(originalObj); Person copied = gson.fromJson(json, Person.class);
前提是对象能被正确序列化为 JSON,且不包含无法转换的字段(如线程、流等)。
基本上就这些。选择哪种方式取决于你的类是否可序列化、性能要求以及项目依赖。序列化法通用性强,构造函数法更直观,第三方库适合已有集成场景。关键是确保所有层级的引用都被真正复制,而不是共享。
以上就是如何在Java中实现对象的深拷贝的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号