list的浅拷贝
list本质上是数组,而数组的是以地址的形式进行存储
如上图将list A浅拷贝给list B,由于进行的是浅拷贝,所以直接将A的内容复制给了B,java中相同内容的数组指向同一地址,即进行浅拷贝后A与B指向同一地址。造成的后果就是,改变B的同时也会改变A,因为改变B就是改变B所指向地址的内容,由于A也指向同一地址,所以A与B一起改变。
先设计一个Person类如下:
1.直接用“=”赋值
运行结果如下:
可见修改list2中的元素的内容后,list中的内容也被修改了,list2添加的新元素也添加到了list中
2.遍历循环复制
运行结果如下:
可见在list2中增加新元素后,并没有加到list中,但是修改list2中与list相同的元素的内容时,list中相应的内容也被修改
运行结果如下:
可见在list2中增加新元素后,并没有加到list中,但是修改list2中与list相同的元素的内容时,list中相应的内容也被修改
运行结果同上.
list的深拷贝
如图,深拷贝就是将A复制给B的同时,给B创建新的地址,再将地址A的内容传递到地址B。ListA与ListB内容一致,但是由于所指向的地址不同,所以改变相互不受影响。
实现Cloneable,serializable接口
import java.io.Serializable; import java.util.Date; @Data public class ActivitySeckillGoods implements Cloneable,Serializable { /** * 创建时间 */ private Date createTime; @Override protected Object clone() { ActivitySeckillGoods activitySeckillGoods = null; try { activitySeckillGoods = (ActivitySeckillGoods) super.clone(); } catch (CloneNotSupportedException e) { e.printStackTrace(); } return activitySeckillGoods; } }
public static <T> List<T> depCopy(List<T> srcList) { ByteArrayOutputStream byteOut = new ByteArrayOutputStream(); try { ObjectOutputStream out = new ObjectOutputStream(byteOut); out.writeObject(srcList); ByteArrayInputStream byteIn = new ByteArrayInputStream(byteOut.toByteArray()); ObjectInputStream inStream = new ObjectInputStream(byteIn); List<T> destList = (List<T>) inStream.readObject(); return destList; } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } return null; }
我们发现修改activitySeckillGoodsList后list的值没有被改变,深拷贝成功