java 深拷贝_JAVA如何实现深拷贝

本文详细介绍了Java中protected权限的作用,以及对象拷贝的两种方式——浅拷贝和深拷贝。浅拷贝仅复制对象的直接域,而深拷贝则会递归复制所有引用的对象。当对象包含可变引用对象时,深拷贝的实现尤为重要,需要重写clone方法以确保拷贝的独立性。此外,还探讨了Object类中clone方法的protected权限设置,以限制跨包访问。
摘要由CSDN通过智能技术生成

展开全部

下面给你简单介绍protected 域(或方法)实现过程思路:

protected 域(或方法)对本包内的所32313133353236313431303231363533e58685e5aeb931333365666264有类可见(当然包括子类),那么,子类可以获得访超类受保护域(或方法)的权利,但是,若子类和超类不在同一个包下,就不能访问超类对象的这个受保护域(或方法)。

浅拷贝与深拷贝

Object类对自己的具体子类的域一无所知,Object类的clone方法只是将各个域进行拷贝。数值或基本类型不会出现问题,但是,如果在对象中包含了引用对象,这些对象的内容没有被自我复制,拷贝的结果也即是原始对象和拷贝对象引用着同一个引用对象(一般地,动词“引用”可理解为“管理”,就是指向同一内存)。

浅拷贝满足:

x.clone() != x为 true,

x.clone().getClass() == x.getClass()为true,

((x.clone().field1 ) == (x. field1))&& … &&((x.clone().fieldN )==(x. fieldN))也为 true 。

如果原始对象与浅拷贝对象共同引用(管理、指向)的引用对象是不可变的,将不会产生任何问题

如果原始对象管理的引用对象是可变的,就必须需重新定义clone方法,来实现深层次的拷贝。要对涉及的每一个类,判断以下两点:

默认的clone方法是否满足需求。

默认的clone方法是否能通过调用可变引用对象的clone方法得到解决。

对涉及的每一个类,深拷贝要满足:

x.clone() != x为 true,

x.clone().getClass() == x.getClass()为true,

x.clone().equals(x)也为 true ,当然equals方法是如此重写过的。

Object类中的clone方法被声明为protected,防止出现文章开头所提到的,子类和超类不在同一个包下的情况,要声明clone为public,来实现深拷贝

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java实现深拷贝有几种方式,下面是其中两种常用的方式: 1. 使用Cloneable接口和clone()方法: Java中的Object类提供了一个clone()方法,通过实现Cloneable接口并重写clone()方法,可以实现对象的深拷贝。具体步骤如下: - 在需要进行深拷贝的类中实现Cloneable接口。 - 重写clone()方法,在方法内部使用super.clone()进行浅拷贝,然后对引用类型的属性进行深拷贝。 - 在使用时,通过调用clone()方法创建一个新的对象。 以下是一个示例代码: ```java public class MyClass implements Cloneable { private int number; private MyObject myObject; public MyClass(int number, MyObject myObject) { this.number = number; this.myObject = myObject; } @Override protected Object clone() throws CloneNotSupportedException { MyClass cloned = (MyClass) super.clone(); cloned.myObject = (MyObject) myObject.clone(); return cloned; } } public class MyObject implements Cloneable { // ... @Override protected Object clone() throws CloneNotSupportedException { return super.clone(); } } ``` 2. 使用序列化和反序列化: 另一种实现深拷贝的方式是通过将对象进行序列化和反序列化来创建一个新的对象。具体步骤如下: - 在需要进行深拷贝的类中实现Serializable接口。 - 将对象写入到一个字节流中,然后再从字节流中读取出来,即可得到一个新的对象。 以下是一个示例代码: ```java import java.io.*; public class MyClass implements Serializable { private int number; private MyObject myObject; public MyClass(int number, MyObject myObject) { this.number = number; this.myObject = myObject; } public MyClass deepCopy() throws IOException, ClassNotFoundException { ByteArrayOutputStream bos = new ByteArrayOutputStream(); ObjectOutputStream oos = new ObjectOutputStream(bos); oos.writeObject(this); ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray()); ObjectInputStream ois = new ObjectInputStream(bis); return (MyClass) ois.readObject(); } } public class MyObject implements Serializable { // ... } ``` 这两种方式都可以实现深拷贝,具体选择哪种方式取决于具体的需求和场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值