Class<?>... parameterTypes
Class<?>[] types
可变参数和数组作为方法参数时的区别:
数组属于引用类型,存储在堆中,栈中存储的是堆中数组的引用(地址)
方式一:先声明,再分配空间
int[] values;
values = new int[10];
方式二:声明并分配空间
int[] values = new int[10];
values[0] = 1;
方式三:声明并赋值(简 / 繁)
int[] values = {1, 2};
int[] values = new int[] {1, 2};
int[] values = {11, 22, 3, 4, 5};
// more是升序
Arrays.sort(values);
System.out.println(Arrays.toString(values));
System.arraycopy(array, 0, array2, 2, 2);
/**
* 数组倒置:
* 第一个数与倒数第一个数交换
* 第二个数与倒数第二个数交换
* 以此类推
*
* 交换的次数看数量是奇数还是偶数
*/
public void inverse() {
int[] nums = {1, 2, 3, 4, 5};
for (int i = 0; i < nums.length / 2; i++) {
int temp = nums[i];
nums[i] = nums[nums.length - 1 - i];
nums[nums.length - 1 -i] = temp;
}
System.out.println(Arrays.toString(nums));
}
概念:一维数组中的一维数组;数组中的元素还是数组
查找元素需要两个下标, X[n][m]
第 n 行 第 m 列
int [][] nums = new int [3][5];
nums.length // 3
nums[0].length // 5
二维数组的遍历
for (int i = 0; i < nums.length; i++) {
for (int j = 0; j < nums[i].length; j++) {}
}
高维数组中的每一个元素,保存了低维数组的地址
例如:访问 array[0] 等价于在访问 0x0000A111