为什么 int 矩阵不是不可变的?

Why are int matrices not immutable?

我的印象是原始数据值是不可变的,因此无法更改(专注于增强的 for 循环),这解释了为什么此代码无法按预期工作:

//Not Mutable Primitaves
    int[] arr = new int[4];
    arr[0] = 1;
    arr[1] = 2;
    arr[2] = 3;
    arr[3] = 4;

    for(int i : arr){
        i = i*2;
    }

    for(int i = 0; i < arr.length; i++){
        System.out.print(arr[i] + ",");
    }

    System.out.print("\n");

此代码继续打印 1,2,3,4,而不考虑乘数。但是在这段代码中,增强的 for 循环实际上修改了原始矩阵,但我不知道为什么?

    public static void changeArr(int[] arr, int mult){
        for(int i = 0; i < arr.length; i++){
            arr[i] = arr[i] * mult;
        }
    }

    public static void main(){
    int[][] matrix = new int [3][3];

    for (int i = 0; i<matrix.length; i++){
        for (int j = 0; j<matrix[i].length; j++){
            matrix[i][j] = i;
        } 
    }

    for (int[] row : matrix){
        changeArr(row, 1);
    }

    for (int i = 0; i<matrix.length; i++){
        for (int j = 0; j<matrix[i].length; j++){
            System.out.print(matrix[i][j] + ",");
        } 
        System.out.print("\n");
    }
    }

有人可以帮助阐明为什么这适用于矩阵而不适用于数组吗?

编辑 执行 arr[i] 会使程序崩溃,其值如下:

    arr[0] = 1243;
    arr[1] = 21;
    arr[2] = 354;
    arr[3] = 4123;
for(int i : arr){
    i = i*2;
}

相当于

for (int index = 0; index < arr.length; index++) {
   int i = arr[index];
   i = i * 2;
}

...如您所见,它什么都不做。相比之下,对于二维数组,得到的是

 for (int index = 0; index < matrix.length; index++) {
   int[] row = matrix[index];
   changeArr(row, 1);
 }

之所以有效,是因为 row 是对同一对象的引用。

如果您尝试设置 row = newRow,那同样不会执行任何操作,但您可以修改行的 内容 就好了。

使用正常的索引 for 循环,一切都会正常。