您的位置:首页 >集合序列化与克隆:深浅拷贝对比解析
发布于2026-03-13 阅读(0)
扫一扫,手机访问
Java中ArrayList.clone()只做浅拷贝,新列表与原列表共享元素引用,修改副本中的自定义对象会影响原列表;修复需手动深拷贝或序列化方案。

clone()克隆ArrayList,为什么改副本还影响原列表?因为ArrayList.clone()只做浅拷贝——它新建了一个ArrayList容器,但里面存的元素引用没变。如果元素是自定义对象(比如User),两个列表里的User实例还是同一个对象。
list2.get(0).setName("Alice"),list1.get(0)的名字也变了clone()没递归复制元素,只复制了数组引用本身clone(),得手动遍历+深拷贝每个元素,或换序列化方案Arrays.asList(...).clone()甚至不工作——返回的是不可变视图,clone()抛UnsupportedOperationExceptioncopy.copy()和copy.deepcopy()对嵌套列表的行为差异copy.copy()只复制外层容器,子列表仍是原引用;copy.deepcopy()才真正断开所有层级的引用链。
ys = copy.copy(xs)处理xs = [[1,2], [3,4]],然后ys[0].append(99)会导致xs[0]也多出99deepcopy要递归遍历整个对象图,遇到循环引用会报RecursionError,大数据量时明显变慢json.loads(json.dumps(obj))快速“伪深拷贝”,但不支持函数、datetime、自定义类等非JSON类型@MappingMapStruct默认生成的映射方法是浅拷贝逻辑——源对象字段是引用类型时,目标对象拿到的仍是同一份引用。这在Service层并发调用或事务回滚场景下极易引发数据污染。
order.getItems(),B线程读到的也是改后的集合@Mapper接口上加uses = {CollectionMapper.class},并自定义CollectionMapper对List做new ArrayList<>(source)或逐项clone()Serializable,配合工具类SerializationUtils.clone(dto)(来自Spring Core),确保彻底隔离SerializationUtils.clone()要求所有嵌套对象都可序列化,否则抛NotSerializableException,需逐级检查它绕过了所有引用共享的可能性——把对象写成字节流再重读,等于强制重建整个对象树,天然切断所有内存地址关联。
Cloneable,也不关心字段是否private或final,只要可序列化就生效Thread/Socket等JVM资源类、静态字段和transient字段丢失ObjectOutputStream直接序列化,优先选Kryo或FST等高性能替代库,避免java.io的GC压力final字段指向可变对象(如final List tags ),反序列化后仍可能被外部修改上一篇:车身广告审批流程全解析
下一篇:UC浏览器下载失败解决方法
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9