利用串行化做深克隆

本文详细解释了浅克隆和深克隆的概念及其区别。浅克隆只复制对象本身,对于对象内部引用的对象则共享同一份;而深克隆不仅复制对象本身,还递归复制对象内部引用的对象。文章通过Java代码示例展示了如何使用串行化实现深克隆。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

克隆或者复制有两种方式。这两种方式分别是浅克隆(浅复制)和深克隆(深复制)。

 

浅克隆(浅复制)

   被克隆对象的所有变量都含有与原来的对象相同的值,而所有的对其他对象的引用都仍然值向原来的对象。换言之,浅克隆仅仅克隆所考虑的对象,而不克隆它所引用的对象。

 

 

深克隆(深复制)

   被克隆对象的所有的变量都含有与原来的对象相同的值,除去那些引用其他对象的变量。这些引用其他对象的变量将指向被克隆过的新对象,而不再是原有的那些被引用的对象。换言之,深克隆把要克隆的对象所引用的对象都克隆一遍,而这种对被引用到的对象的克隆叫做间接克隆。

   深克隆要深到多少层,是一个不易确定的问题。因此,在采取深克隆时,需要决定多深才算深。此外,在深克隆的过程中,很可能会出现循环引用的问题,必须小心处理

 

利用串行化做深克隆

 

    在Java里深克隆一个对象,常常可以先使对象实现Serializable接口,然后把对象(实际上只是对象的一个拷贝)写道一个流里,再从流里读回来,便可以重建对象。

 

 

 

 

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;

public class deep implements Serializable {


	private static final long serialVersionUID = 9031569199021177136L;
	private String name;
	private Long age;

	public Long getAge() {
		return age;
	}

	public void setAge(Long age) {
		this.age = age;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public Object deepClone() throws ClassNotFoundException, IOException{
		ByteArrayOutputStream bo = new ByteArrayOutputStream();
		ObjectOutputStream oo = new ObjectOutputStream(bo);
		oo.writeObject(this);
		ByteArrayInputStream bi = new ByteArrayInputStream(bo.toByteArray());
		ObjectInputStream oi = new ObjectInputStream(bi);
		return (oi.readObject());
	}
}
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值