Java中数组赋值为何导致原数组被修改?深入理解引用传递机制

java中数组是引用类型,变量赋值仅复制引用而非数组内容,因此对副本的修改会直接影响原始数组。

在Java中,数组本质上是对象(Object的子类),属于引用类型,而非基本数据类型(如int、boolean)。这意味着:当你执行 int[] y = arr; 时,并未创建新的数组副本,而是将arr所持有的堆内存地址(即引用)赋值给了变量y。此时,arr和y指向同一块内存区域中的同一个数组对象。

因此,后续执行 y[0] = 15; 实际上是通过y这个引用,修改了该共享数组的第一个元素——而arr也正指向它,所以arr[0]自然变为15。最终 Arrays.toString(arr) 输出 [15, 2, 3, 4] 完全符合预期,而非“未修改arr”的错觉。

✅ 正确理解的关键点:

  • = 对数组赋值 = 复制引用(地址),不是复制数据;
  • 所有对该引用的修改,都会反映在原始数组上;
  • 这与基本类型(如 int a = b;)的值拷贝行为有本质区别。

? 若需真正独立的副本,必须显式复制数组内容,例如:

import java.util.Arrays;

public class Alle {
    public static void main(String[] args) {
        int[] arr = {1, 2, 3, 4};
        int[] y = Arrays.copyOf(arr, arr.length); // 创建新数组,内容相同
        y[0] = 15;
        System.out.println(Arrays.toString(arr)); // 输出: [1, 2, 3, 4]
        System.out.println(Arrays.toString(y));   // 输出: [15, 2, 3, 4]
    }
}

其他常用深拷贝方式还包括:

  • arr.clone()(返回Object,需强制转型:(int[]) arr.clone());
  • System.arraycopy(src, 0, dest, 0, length)(需预先创建目标数组);
  • 使用Stream(Java 8+):int[] y = Arrays.stream(arr).toArray();

⚠️ 注意:以上方法均只实现一维数组的浅拷贝;对于含对象引用的数组(如 String[] 或自定义对象数组),若需完全隔离修改,还需对每个元素做深拷贝——但对int[]等基本类型数组,Arrays.copyOf已足够安全。

总结:Java中“数组变量”存储的是指向堆中数组对象的引用,理解这一机制是避免意外共享状态、编写可

预测代码的基础。