登录
首页 >  文章 >  java教程

Java集合复制方法详解

时间:2026-01-28 18:33:36 333浏览 收藏

目前golang学习网上已经有很多关于文章的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《Java集合拷贝方法全解析》,也希望能帮助到大家,如果阅读完后真的对你学习文章有帮助,欢迎动动手指,评论留言并分享~

最常用且安全的浅拷贝方式是用构造方法:new ArrayList(originalList) 或 new LinkedList(originalList),但需注意判空、类型适配及不可变集合的“假拷贝”风险。

在Java中如何复制一个集合_Java集合拷贝方式解析

直接用构造方法复制 ArrayList 或 LinkedList

大多数时候,你只需要一个浅拷贝——新集合和原集合元素引用相同,但集合容器本身独立。这时候最简单的方式就是用目标集合的构造方法传入原集合:

  • new ArrayList(originalList) 是最常用、最安全的写法,适用于任何 Collection 子类
  • new LinkedList(originalList) 同理,但注意它内部是链表结构,随机访问性能差,别只因“想复制”就盲目换类型
  • 如果 originalListnull,会抛 NullPointerException,务必提前判空或用 Objects.requireNonNull

用 Collections.copy() 时必须注意容量匹配

Collections.copy() 不创建新集合,而是把源集合元素逐个赋值到目标集合已有位置。它要求目标集合长度 ≥ 源集合长度,否则抛 IndexOutOfBoundsException

  • 目标集合必须已初始化且有足够容量,例如:List dest = new ArrayList(Collections.nCopies(src.size(), null))
  • 它不会扩容,也不会清空原内容——如果 dest 原来有 10 个元素,只复制了前 5 个,后 5 个保留原值
  • 实际项目中极少用它,除非你明确要复用某段已分配内存的列表(比如池化场景),否则容易出错

深拷贝不能靠集合构造方法解决

构造方法只复制引用,若集合里存的是可变对象(如 HashMap、自定义 POJO),修改副本里的对象仍会影响原集合中的对应对象:

  • 真需要深拷贝,得逐个调用元素的克隆逻辑,比如:list.stream().map(item -> item.clone()).collect(Collectors.toList()),前提是 item 实现了 Cloneable 且重写了 clone()
  • 更稳妥的做法是用序列化(如 ObjectOutputStream + ByteArrayInputStream),但要求所有元素都实现 Serializable,且注意 transient 字段不会被复制
  • JSON 序列化(如 Jackson)也是一种选择,但会引入额外依赖、性能开销大,且对循环引用、特殊类型(如 Date)需额外配置

不可变集合复制要小心“假拷贝”

如果你用的是 ImmutableList.copyOf()(Guava)或 List.of()(Java 9+),它们返回的是不可变视图,底层可能共享引用:

  • ImmutableList.copyOf(original) 如果 original 本身已是不可变实现,可能直接返回它,而非新建对象
  • List.copyOf()(Java 10+)也是类似逻辑:若参数已是不可变 List,则不复制;否则才新建
  • 这意味着你以为“复制了”,其实两个变量指向同一实例,== 可能为 true——调试时容易误判

真正要复制集合,先想清楚:要的是容器独立?还是元素也隔离?是否允许 null?有没有并发修改风险?这些细节比“怎么写一行代码”更重要。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Java集合复制方法详解》文章吧,也可关注golang学习网公众号了解相关技术文章。

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>