int [][] num = new int [3][5];
num[0][0] = 1;
num[0][1] = 2;
num[0][2] = 3;
num[1][0] = 4;
num[1][1] = 5;
num[1][2] = 6;
num[2][0] = 7;
num[2][1] = 8;
num[2][2] = 9;
System.out.println(num[0].length);
int[] ids = { 1, 2, 3, 4, 5 };
int[] ids2 = new int[6];
System.arraycopy(ids, 0, ids2, 0 ,5);
System.out.println(Arrays.toString(ids2) );
int[][]num2 = new int [3][5];
System.arraycopy(num, 0, num2, 0 ,2);
System.out.println(num2[2][0]);
Java中的二维数组是由一个数组的每一个element 储存一个指向第二维数组的reference实现的。
例如:
num[0] 中储存了指向了第二维数组的reference,这个第二维数组有3个elements,分别为num[0][0] = 1, num[0][1] = 2, num[0][2] = 3,也就是第0行的内容。
使用System.arraycopy(num, 0, num2, 0 ,2),
从 num copy 了 2个elements 到 num2.
也就是第0行和第1行的reference(num[0], num[1])被copy到了num2[0], num2[1]。
所以:
num[0][0] = 1; num[0][1] = 2; num[0][2] = 3; num[1][0] = 4; num[1][1] = 5; num[1][2] = 6; num[2][0] = 0; num[2][1] = 0; num[2][2] = 0; // num[2]没有被copy过来