利用序列化实现深拷贝

本文是借鉴的一位前辈的总结,重新编辑一下收藏了.
首先看看浅拷贝和深拷贝的定义
  浅拷贝:只复制一个对象,对象内部存在的指向其他对象数组或者引用则不复制
  深拷贝:对象,对象内部的引用均复制 
 为了更好的理解它们的区别我们假设有一个对象A,它包含有2对象对象A1和对象A2
  对象A进行浅拷贝后,得到对象B但是对象A1和A2并没有被拷贝
  对象A进行深拷贝,得到对象B的同时A1和A2连同它们的引用也被拷贝
  在理解了深拷贝和浅拷贝后,我们来看看Java的深拷贝和浅拷贝实现。
java.lang.Object的clone()方法默认是返回一个浅拷贝对象。
因此如果要用clone()方法实现一个深拷贝,我们必须对每个对象的clone()方法进行特别实现。
当对象层次复杂的时候,这样做不但困难而且浪费时间和容易出现错误,
特别有时候你不但需要深拷贝同时你也对这个对象进行浅拷贝的时候,你会发现写这个clone()方法真不是一个好的解决方案。
  那么除了clone()方法,我们还可以怎么实现呢?答案是序列化。
实现步骤和思路是把要拷贝的对象输出成byte array,然后再利用ObjectInputStream转换出新的对象。下面是代码:
public static Object copy(Object oldObj) 
{  
  Object obj = null; 
   try {       // Write the object out to a byte array  
    ByteArrayOutputStream bos = new ByteArrayOutputStream();
      ObjectOutputStream out = new ObjectOutputStream(bos);
      out.writeObject(oldObj);
      out.flush();
      out.close();
        // Retrieve an input stream from the byte array and read 
     // a copy of the object back in.
      ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray());
      ObjectInputStream in = new ObjectInputStream(bis);
      obj = in.readObject();
    }catch(IOException e) 
{
      e.printStackTrace();
    }catch(ClassNotFoundException cnfe) 
{
      cnfe.printStackTrace();
    } 
   return obj;
   } 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值