一、数组(一维)
1、数组的定义:数组就是存储数据长度固定的容器,存储多个数据的数据类型要一致。
2、定义数组的格式
2.1格式说明
(1)格式1
数据类型[ ] 数组名
例:int[ ] arr;
(2)格式2
数据类型 arr[ ];
例:int arr[ ];
2.2注意事项
(1)数组的数据类型决定数组中存储数据的类型。
(2)数组定义后需要赋值(初始化),否则不能使用。
(3)数组初始化的实质:在内存中开辟一块空间来存储数组容器,需要将数据添加到数组容器中。
3、数组的初始化
3.1数组动态初始化
(1)动态初始化的定义
数组的动态初始化就是只给定数组的长度,由系统给出默认初始化值。
(2)动态初始化的格式
数据类型[ ] 数组名 = new 数组类型[数组长度]
int[ ] arr = new int[3]-----------定义了一个长度为3的数组
3.2数组静态初始化
(1)静态初始化的定义
在创建数组时,直接给出数组元素。
(2)静态初始化的格式
数据类型[ ] 数组名 = new 数据类型[ ]{元素1,元素2,......};
int[ ] arr = new int[ ]{1,2,3};
当然,对于上述的格式我们可以对其 简化:
数据类型[ ] 数组名 = {元素1,元素2,......};
int[ ] arr = {1,2,3};
3.3数组初始化的默认值
数据类型 | 默认值 |
---|---|
整数 | 0 |
浮点数 | 0.0 |
字符 | false |
布尔 | 空字符 |
引用数据类型 | null |
3.3注意事项
如果数组的定义和初始化分开写,那么只能使用完整版格式来初始化数组。
4、数组元素访问
4.1索引
(1)索引的定义
每一个存储到数组的元素,都会自动的拥有一个编号,从0开始。这个自动编号称为数组索引,可以通过数组的索引访问到数组中的元素。
例:
int arr[ ] = {1,2,3};
数组的第一个元素:arr[0] = 1
数组的第二个元素:arr[1] = 2
数组的第三个元素:arr[2] = 3
通过以上的举例,我们引出访问数组的元素格式-------------数组名[索引]
我们来看编程效果
代码:
结果:
4.2索引越界异常
说明:索引越界异常是数组操作的常见问题之一。他的意思是,我们访问数组的元素时访问了一个不在数组索引范围内的元素。
例:
int arr[ ] = {1,2,3};
以上数组的索引范围是0--2,若我们访问了一个不在范围内的索引,那么就会出现索引越界异常(ArrayIndexOutOfBoundsException )的报错。
5、数组的遍历
5.1数组遍历的定义:将数组中的每个元素分别获取出来。
数组元素的个数会根据实际情况具有不确定性,因此我们常用循环来遍历数组。
代码:
结果:
说明:arr.length-------数组的长度
二、二维数组
1、二维数组的概述
二维数组也是一种容器,不同于一维数组,该容器存储的都是一维数组容器。也就是说,二维数组的本质还是一维数组,只不过数组中的元素不是具体的元素值,而是一个新的数组而已。
2、二维数组的初始化
2.1动态初始化
格式
数据类型[ ][ ] 变量名 = new 数据类型[m][n];
说明:m表示这个二维数组,可以存放多少个一维数组,n表示每一个一维数组,可以存放多少个元素。
2.2静态初始化
格式
数据类型[ ][ ] 变量名 = new 数据类型[][]{ {元素1, 元素2...} , {元素1, 元素2...} ;
int[ ][ ] arr = new int{{1,2,3},{4,5,6}};
当然,与一维数组相似,二维数组的静态初始化也有简化的格式
数据类型[ ][ ] 变量名 = { {元素1, 元素2...} , {元素1, 元素2...} ;
int[ ][ ] arr = {{1,2,3},{4,5,6}};