04数 组
数组定义格式
数组概述
一次性声明大量的用于存储数据的变量。
要存储的数据通常都是同类型数据,例如:考试成绩。
什么是数组
数组(array)是一种用于存储多个相同类型数据的存储模型。
数组的定义格式
格式一:数据类型[ ] 变量名
范例: int[ ] arr
定义了一个int类型的数组,数组名是arr
格式二:数据类型 变量名[ ]
范例: int arr[ ]
定义了一个int类型的变量,变量名是arr数组
数组初始化之动态初始化
数组初始化概述
Java中的数组必须先初始化,然后才能使用。
所谓初始化:就是为数组中的数组元素分配内存空间,并为每个数组元素赋值。
数组初始化方式
动态初始化
动态初始化:初始化时只指定数组长度,由系统为数组分配初始值。
格式:数据类型[ ] 变量名 = new 数据类型[数组长度];
范例:int[ ] arr = new int[3];
说明:左边:int:说明数组中的元素类型是int类型
[ ]:说明这是一个数组
arr:这是数组的名称
右边:new:为数组申请内存空间
int:说明数组中的元素类型是int类型
[ ]:说明这是一个数组
3:数组长度,其实就是数组中的元素个数
数组元素访问
数组变量访问方式
格式:数组名
数组内部保存的数据的访问方式
格式:数组名[索引]
索引是数组中数据的编号方式
作用:索引用于访问数组中的数据使用,数组名[索引]等同于变量名,是一种特殊的变量名
特征①:索引从0开始
特征②:索引是连续的
特征③:索引逐一增加,每次加1
内存分配
Java中内存分配
Java 程序在运行时,需要在内存中分配空间。为了提高运算效率,就对空间进行了不同区域的划分,因为每一片区域都有特定的处理数据方式和内存管理方式。
数组在初始化时,会为存储空间添加默认值
整数:默认值0
浮点数:默认值0.0
布尔值:默认值false
字符:默认值是空字符
引用数据类型:默认值是null
数组初始化之静态初始化
静态初始化
静态初始化:初始化时指定每个数组元素的初始值,由系统决定数组长度。
格式:数据类型 [ ] 变量名 = new 数据类型[ ] { 数据1 , 数据2 , 数据3 , ……} ;
范例:int[ ] arr = new int[ ] { 1 , 2 , 3 } ;
简化格式:数据类型 [ ] 变量名 = { 数据1 , 数据2 , 数据3 , ……} ;
范例:int[ ] arr = { 1 , 2 , 3 } ;
数组操作的常见问题
索引越界
访问了数组中不存在的索引对应的元素,造成索引越界问题。
空指针异常
访问的数组已经不再指向堆内存的数据,造成空指针异常。
null
null:空值,引用数据类型的默认值,表示不指向任何有效对象。
数组常见操作
1、遍历
可以逐个打印数组中所有的元素,也可以利用for循环来实现遍历。
例如:
int[ ] arr = {11,22,33};
for(int x=0; x<arr.length; x++) {
System.out.println(arr[x]);
}
2、获取数组元素数量
格式:数组名.length
范例:arr.length
3、获取最值
先取数组中的第一个元素,再将该元素与数组中剩下的所有元素进行比较,每次比较保留较大值,最终打印输出的值就是数组中的最大值。可以使用for循环和if语句实现。
例如:
int[ ] arr = {12,45,98,73,60};
int max = arr[0];
for(int x=1; x<arr.length; x++) {
if(arr[x] > max) {
max = arr[x];
}
}
System.out.println(“max:”+max);
此时打印输出的max的值就是数组arr中的最大值