Java的深拷贝和浅拷贝(2)

上一篇文章讲述了浅拷贝和深拷贝的含义,并且给出了浅拷贝的一个例子

 

这篇文章在那个例子的实现上作出修改,实现深拷贝,代码如下:

 

 

 

 

该段代码让School类(被引用的类)也实现了Cloneable接口,并且也重写了clone()方法。然后改写了Student的clone()方法。

 

 

从结果可以看出,学生s2改变其引用的学校的属性,不会影响到学生s1所属的学校的属性,这就是深拷贝的含义。

 

 

 

上面是深拷贝的一个实现。

 

还可以通过序列化来实现对象的深拷贝,一个对象被序列化时会将对象和对象内部引用的其他的对象(递归下去)一起序列化

 

一个对象如果想要被序列化,那么必须实现Serializable接口,这个接口也没有定义任何方法,也是一个marker interface

 

将前一个例子进行改写,用序列化的方法实现深拷贝的代码如下:

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JAVA中的深拷贝浅拷贝是对象拷贝的两种方式。深拷贝是一个整个独立的对象拷贝,会拷贝所有的属性,并拷贝属性指向的动态分配的内存。当对象和它所引用的对象一起拷贝时即发生深拷贝深拷贝相比于浅拷贝速度较慢并且花销较大。要实现深拷贝,可以在拷贝构造方法中,对引用数据类型变量逐一开辟新的内存空间,创建新的对象,这样可以实现深拷贝。而对于一般的拷贝构造,则一定是浅拷贝。此外,可以通过简洁的代码实现深拷贝,但要注意的是,如果某个属性被transient修饰,那么该属性就无法被拷贝了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Java深入理解深拷贝浅拷贝区别](https://blog.csdn.net/riemann_/article/details/87217229)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Java 浅拷贝深拷贝的理解和实现方式](https://blog.csdn.net/weixin_30662011/article/details/96181137)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值