为什么 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 循环,一切都会正常。
我的印象是原始数据值是不可变的,因此无法更改(专注于增强的 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 循环,一切都会正常。