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 ]
[
下一页 ]