登录
首页 >  文章 >  java教程

Java数组深拷贝方法及Arrays.copyOf使用详解

时间:2026-04-16 20:52:33 316浏览 收藏

本文深入解析了Java中Arrays.copyOf方法的核心特性与典型应用场景:它本质上只执行浅拷贝——对基本类型复制值,对引用类型仅复制地址,因此无法隔离对象状态,深拷贝需手动克隆每个对象;但恰恰因其高效、安全、泛型友好的浅拷贝机制,Arrays.copyOf成为动态扩容数组的理想工具,能自动处理截断、填充和类型推导,是模拟ArrayList扩容逻辑的简洁基石。想真正理解数组复制的本质、避开共享引用陷阱,并掌握生产级扩容实践?这篇文章不容错过。

Java数组深拷贝教程:如何利用Arrays_copyOf实现动态数组扩容

Arrays.copyOf 不能实现深拷贝,它只做浅拷贝;但它确实常用于动态数组扩容——这是两个不同场景,需先分清。

Arrays.copyOf 的本质是浅拷贝

它会创建一个新数组,把原数组的元素逐个复制过去。对基本类型(int、double 等),这等效于值拷贝;但对引用类型(如 String[]、Object[] 或自定义对象数组),它复制的是引用地址,不是对象本身。也就是说,新旧数组中指向同一堆内存中的对象。

例如:

Person[] oldArr = { new Person("Alice") };
Person[] newArr = Arrays.copyOf(oldArr, 2);
newArr[0].setName("Bob"); // oldArr[0] 的名字也会变成 "Bob"

所以,若需真正隔离对象状态,必须手动遍历并克隆每个对象(实现 Cloneable + clone(),或用构造器/序列化等)。

用 Arrays.copyOf 扩容数组是它的核心用途

Java 数组长度固定,扩容的本质是:创建更大新数组 + 复制原内容 + 替换引用。Arrays.copyOf 封装了前两步,简洁安全。

  • 语法简单:newArr = Arrays.copyOf(oldArr, newSize)
  • 自动处理边界:newSize 小于原长则截断;大于则补默认值(0、null、false)
  • 类型安全:返回泛型推导后的数组,无需强制转型(如 String[]

模拟 ArrayList 的简易扩容逻辑

可参考 ArrayList.ensureCapacityInternal 的思路,封装一个工具方法:

public static <T> T[] grow(T[] arr, int minCapacity) {
    if (arr == null) return (T[]) new Object[minCapacity];
    int oldLength = arr.length;
    if (minCapacity 

注意:扩容后需显式赋值回原变量,数组引用不可变。

替代方案与注意事项

  • 频繁扩容建议直接用 ArrayList —— 它已内置倍增策略和优化
  • Arrays.copyOf 不支持多维数组的“深层”扩容;二维数组扩容需分别 copy 每一行
  • 原始类型数组(如 int[])用它扩容无副作用;引用类型扩容后仍需警惕共享对象修改
  • 若需真正深拷贝整个对象数组,得配合对象自身的深拷贝能力,例如:
    Person[] deepCopy = Arrays.stream(original)
        .map(p -> new Person(p.getName(), p.getAge())) // 假设提供拷贝构造器
        .toArray(Person[]::new);
    

理论要掌握,实操不能落!以上关于《Java数组深拷贝方法及Arrays.copyOf使用详解》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>