打字猴:1.700441962e+09
1700441962
1700441963 p.setFather(new Person(p.getFather().getName()));
1700441964
1700441965 }catch(CloneNotSupportedException e){
1700441966
1700441967 e.printStackTrace();
1700441968
1700441969 }
1700441970
1700441971 return p;
1700441972
1700441973 }
1700441974
1700441975 然后再运行,小儿子的父亲就不会是“干爹”了。如此就实现了对象的深拷贝(Deep Clone),保证拷贝出来的对象自成一体,不受“母体”的影响,和new生成的对象没有任何区别。
1700441976
1700441977 注意 浅拷贝只是Java提供的一种简单拷贝机制,不便于直接使用。
1700441978
1700441979
1700441980
1700441981
1700441982 编写高质量代码:改善Java程序的151个建议 [:1700438113]
1700441983 编写高质量代码:改善Java程序的151个建议 建议44:推荐使用序列化实现对象的拷贝
1700441984
1700441985 上一个建议说了对象的浅拷贝问题,实现Cloneable接口就具备了拷贝能力,那我们来思考这样一个问题:如果一个项目中有大量的对象是通过拷贝生成的,那我们该如何处理?每个类都写一个clone方法,并且还要深拷贝?想想看这是何等巨大的工作量呀,是否有更好的方法呢?
1700441986
1700441987 其实,可以通过序列化方式来处理,在内存中通过字节流的拷贝来实现,也就是把母对象写到一个字节流中,再从字节流中将其读出来,这样就可以重建一个新对象了,该新对象与母对象之间不存在引用共享的问题,也就相当于深拷贝了一个新对象,代码如下:
1700441988
1700441989 public class CloneUtils{
1700441990
1700441991 //拷贝一个对象
1700441992
1700441993 @SuppressWarnings(“unchecked”)
1700441994
1700441995 public static<T extends Serializable>T clone(T obj){
1700441996
1700441997 //拷贝产生的对象
1700441998
1700441999 T clonedObj=null;
1700442000
1700442001 try{
1700442002
1700442003 //读取对象字节数据
1700442004
1700442005 ByteArrayOutputStream baos=new ByteArrayOutputStream();
1700442006
1700442007 ObjectOutputStream oos=new ObjectOutputStream(baos);
1700442008
1700442009 oos.writeObject(obj);
1700442010
1700442011 oos.close();
[ 上一页 ]  [ :1.700441962e+09 ]  [ 下一页 ]