数组的四个基本特点
- 其长度是确定的。数组一旦被创建,其大小就是不可以改变的。
- 其元素必须是相同类型的,不予许出现混合类型。
- 数组中的元素可以是任何数据类型,包括基本类型和引用类型。
- 数组变量属于引用类型,数组也可以看成是对象,数组中的每个元素相当于该对象的成员变量。
- 数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身是在堆中的。
数组边界
-
下标合法区间[0,length-1],如果越界就会报错;
-
比如:
package com.yuecheng.Array; public class Demo04 { public static void main(String[] args) { int[] a =new int[3]; System.out.println(a[3]);// 此时会报错,因为数组下标是从0开始的,此时输出越界, } }
错误类型:ArrayIndexOutOfBoundsException,数组下标越界异常!!!
小结
- 数组是相同数据类型(可以是任意数据类型)的有序集合。
- 数组也是对象。数组元素相当于对象的成员变量。
- 数组长度是确定,不可改变的。如果越界则报:ArrayIndexOutOfBoundsException
数组的遍历
-
package com.yuecheng.Array; public class Demo04 { public static void main(String[] args) { int[] a =new int[3]; a[0]=1; a[1]=9; a[2]=8; for (int i =0; i<3;i++){ System.out.println(a[i]); } } }
数组的使用
-
For-Each 循环
//jdk1.5以后没有下标的,foreach循环 for (int array : arrays) { System.out.println(array); }
-
数组做方法入参
-
数组做返回值(这点有点难以理解,注意多复习)
package com.yuecheng.Array; public class ArrayDemon07 { public static void main(String[] args) { int [] arrays = {1,2,3,4,5}; // printArray(arrays); int[] reverse = reverse(arrays);// reverse(arrays)调用刚刚定义的反转方法 //调用这个方法后会返回一个结果,我们这步操作就是把反转后的结果放入reverse这个数组 printArray(reverse);//甚至还可以使用刚刚定义的方法来遍历反转后的数组 //数组做方法返回值入参(下方定义的第一个方法) //打印数组元素 } //注意 定义方法要在main方法外 public static void printArray(int[] arrays){ for (int i =0;i< arrays.length;i++){ System.out.print(arrays[i]+" "); } } // 反转数组(数组做返回值) public static int [] reverse (int[] arrays){ int [] result = new int[ arrays.length]; //反转操作 for( int i = 0,j = result.length-1;i<arrays.length;i++,j--){ result[j]=arrays[i]; } return result; } }
数组的基本用法
package com.yuecheng.Array;
import jdk.management.resource.internal.inst.FileOutputStreamRMHooks;
public class ArrayDemo06 {
public static void main(String[] args) {
int [] o = {1,2,3,4,5};
//打印全部的数组元素
for (int i = 0; i < o.length;i++){
System.out.println(o[i]);
}
System.out.println("手动分割线"+"------------------------------------------");
//计算所有元素的总和
int sum=0;
for (int i = 0; i< o.length;i++){
sum=sum+ o [i];//简化写法 sum+=o[i];
}
System.out.println("总和为"+sum);
System.out.println("手动分割线"+"------------------------------------------");
//查找最大元素
int max = o[0];
for(int i =1;i<5;i++){
if (o[i]>max){
max = o[i];
}
}
System.out.println("最大值为"+max);
}
}