打字猴:1.700441982e+09
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();
1700442012
1700442013 //分配内存空间,写入原始对象,生成新对象
1700442014
1700442015 ByteArrayInputStream bais=new ByteArrayInputStream(baos.toByteArray());
1700442016
1700442017 ObjectInputStream ois=new ObjectInputStream(bais);
1700442018
1700442019 //返回新对象,并做类型转换
1700442020
1700442021 clonedObj=(T)ois.readObject();
1700442022
1700442023 ois.close();
1700442024
1700442025 }catch(Exception e){
1700442026
1700442027 e.printStackTrace();
1700442028
1700442029 }
1700442030
1700442031 return clonedObj;
[ 上一页 ]  [ :1.700441982e+09 ]  [ 下一页 ]