目录
一、数组的基本概念
1.数组的定义
数组(Array):有序的元素序列,也可以看成是相同类型元素的一个集合。
2.数组的特点
a)数组中存储的元素的数据类型相同
b)数组在内存中是一段连续的空间,各元素的存储是有先后顺序的。
c)数组元素用数组名字和其在数组中的位置表示。例如,a[0]表示名字为a的数组中的第一个元素。
3.元素的创建和初始化
3.1 数组的创建
元素类型 [ ] 数组名 = new 元素类型 [ 数组长度 ]
举例:
int [ ] array1 = new int [8] ;//创建一个数组长度为8,元素类型为int的数组
double [ ] array2 = new double [5] ;//创建一个数组长度为5,元素类型为double的数组
3.2 数组的初始化
数组的初始化主要分为静态初始化和动态初始化。
3.2.1 静态初始化
静态初始化:即在创建数组时不直接指定数据元素个数,而是直接将具体的数据内容进行指定。
元素类型 [ ] 数组名 = {data1,data2,data3,data4,data5,...,datan};
举例:
int [ ] array1 = new int [ ] {0,1,2,3,4,5};
double [ ] array2 = new double [ ] {1.0,2.0,3.0,4.0,5.0};
ps:静态初始化可以简写,即省去后面的new 元素类型[ ] 。
3.2.2 动态初始化
动态初始化:在创建数组时,直接指定数组中元素的个数。
元素类型 [ ] 数组名 = new 元素类型 [ 数组长度 ]
举例:
int [ ] array = new int [8] ;
二、数组的使用
1.数组中的元素访问
由于数组在内存中是一段连续的空间,空间的编号从0开始,依次递增,所以我们可以通过访问数组下标的形式来访问数组元素。
注意:数组的下标从0开始,介于[0,n)之间但不包含n,n为数组元素个数,在访问数组元素时不能越界访问,否则系统会报错。
2.遍历数组
遍历:即将数组中的元素全部访问一遍,访问是指对数组中的元素进行某种操作,例如:打印。
举例:
int [] array = new int[] {85,1122,97,29,20};//创建数组;
System.out.println(array[0]); //85;
System.out.println(array[1]); //1122;
System.out.println(array[2]); //97;
System.out.println(array[3]); //29;
System.out.println(array[4]); //20;
上述代码虽然实现了对数组的遍历,但也存在着一些问题:
1.如果数组要新增一个元素,那就意味着要多一条打印语句,那如果要增加100个元素,10000个元素呢?这也就大大增加了代码的繁琐程度。
2.如果此时需要对数组的打印结果修改为每一个元素都增加1,这时我们会发现修改起来很麻烦。
这时需要引入一种新的遍历方法:循环遍历
我们可以通过for循环和for-each循环来遍历
for-each遍历数组
int [ ] array = {1,2,3};
for(int x : array) {
System.out.println(x);
}
通过循环遍历的方式,我们发现代码的可执行性大大提升了。