前言
数组是一种容器,用来存储同种数据类型的多个值。当大类型的数据存储在小类型的数组中时,就会出现问题。相反,小的数据类型存储到大的数据类型的数组里时,当然可以存储进去。所以说在选择容器的类型时,尽量和存储的数据类型保持一致。什么时候使用数组呢?当要操作的数据时同一组数据时,就可以使用数字容器进行存储
一、数组的定义格式
数据类型[] 变量名
例:int[] array;
注意:虽然定义了一个数组,但也仅仅是一个数组类型的[变量],还没有进行初始化,所以不能直接输出空数组。
二、数组的动态初始化
所谓初始化,就是在内存中,为数组容器开辟空间,并将数据存入容器的过程。
动态初始化:初始化时只需要指定数组长度,初始值又系统分配。
格式:
数据类型 [] 变量名 = new 数据类型 [数组长度];
例:int [] arr = new int [3];
三、数组的静态初始化
静态初始化的时候,就可以指定数组要存储的元素 ,系统还会自动计算出该数组的长度。
格式1: 数据类型 [] 变量名 = new 数据类型 [] {数据1,数据2,数据3...};
例: int [] arr = new int [] {1,2,3};
格式2: 数据类型 [] 变量名 = {数据1,数据2,数据3...};例: int [] arr = {1,2,3};
四、数组元素访问
访问数组的内存地址方式:数组名
访问数组的内部保存的数据:数组名[索引]
索引是数组容器中空间的编号
1、索引从0开始
2、索引是连续的
3、索引逐一增加,每次加1
作用:就是为了访问数组容器的中空间位置。
例如:
public class Test{
public static void main(String[] args){
int [] arr = new int [3];
System.out.println(arr[0]);
System.out.println(arr[1]);
System.out.println(arr[2]);
}
}
结果为0,0,0,这是因为没有给数组初始化值,所以打印出来的是系统默认值0。
注意:
索引越界:当访问了数组中不存在的索引,就会出现异常,造成索引越界。
空指针异常:访问的数组已经不在指向堆内存的数据,造成空指针异常。
null:空值,引用数据类型的默认值,表示不指向任何有效对象。
五、数组遍历
就是把数组中的所有数据取出来。
可以看一段代码:
public class Test{
public static void main(){
int [] arr = {1,2,3,4,5,6};//静态初始化数组
System.out.println(arr[0]);
System.out.println(arr[1]);
System.out.println(arr[2]);
System.out.println(arr[3]);
System.out.println(arr[4]);
System.out.println(arr[5]);
}
}
这段代码看上去非常臃肿,而且是写死了的,不够灵活,我们可以用一个循环来优化:
public class Test{
public static void main(){
int [] arr = {1,2,3,4,5,6};//静态初始化数组
for(int i = 0; i < arr.length; i++){
System.out.println(arr[i]);
}
}
这段代码可以动态的获取到数组中元素的数量,非常方便。