数组的基本使用
一、数组的定义
概念: 数组就是存储数据长度固定的容器,保证多个数据的数据类型要一致。
格式一:数组存储的数据类型[] 数组名字;
举例:int[] arr;
格式二:数组存储的数据类型 数组名字[];
举例:int arr[];
二、数组动态初始化
格式:数组存储的数据类型[] 数组名字 = new 数组存储的数据类型[长度];
举例:int[] arr = new int[5];
数组定义格式详解: 数组存储的数据类型: 创建的数组容器可以存储什么数据类型。 [] : 表示数组。 数组名字:为定义的数组起个变量名,满足标识符规范,可以使用名字操作数组。 new:关键字,创建数组使用的关键字。 数组存储的数据类型: 创建的数组容器可以存储什么数据类型。 [长度]:数组的长度,表示数组容器中可以存储多少个元素。
注意:数组有定长特性,长度一旦指定,不可更改。
三、数组静态初始化
格式:数据类型[] 数组名 = new 数据类型[]{元素1,元素2,元素3...};
举例:int[] arr = {1,2,3,4,5};
四、数组的访问
索引: 每一个存储到数组的元素,都会自动的拥有一个编号,从0开始,这个自动编号称为数组索引(index),通过数组的索引访问到数组中的元素。
格式:数组名[索引]
举例:arr[0] arr[1]
数组的长度属性:
每个数组都具有长度,而且是固定的,Java中赋予了数组的一个属性,可以获取到数组的长度
语句为:数组名.length ,属性length的执行结果是数组的长度,int类型结果。
由次可以推断出,数组的最大索引值为数组名.length-1。
索引访问数组中的元素: 数组名[索引]=数值,为数组中的元素赋值 变量=数组名[索引],获取出数组中的元素
五、数组内存图
1、单个数组内存
举例:int[] arr = new int[3];
2、多个数组内存
举例:
int[] arr = new int[3];
int[] arr2 = new int[2];
3、两个变量指向同一个数组
举例:
[Java] 纯文本查看 复制代码 public static void main(String[] args) {[/size]
[size=3] // 定义数组,存储3个元素[/size]
[size=3] int[] arr = new int[3];[/size]
[size=3] //数组索引进行赋值[/size]
[size=3] arr[0] = 5;[/size]
[size=3] arr[1] = 6;[/size]
[size=3] arr[2] = 7;[/size]
[size=3] //输出3个索引上的元素值[/size]
[size=3] System.out.println(arr[0]);[/size]
[size=3] System.out.println(arr[1]);[/size]
[size=3] System.out.println(arr[2]);[/size]
[size=3] //定义数组变量arr2,将arr的地址赋值给arr2[/size]
[size=3] int[] arr2 = arr;[/size]
[size=3] arr2[1] = 9;[/size]
[size=3] System.out.println(arr[1]);[/size]
[size=3]}
六、数组常见问题
1、索引越界
举例:
int[] arr = {1,2,3};
System.out.println(arr[3]);
解析:
创建数组,赋值3个元素,数组的索引就是0,1,2,没有3索引,因此我们不能访问数组中不存在的索引,程序运行后,将会抛出 ArrayIndexOutOfBoundsException 数组越界异常。在开发中,数组的越界异常是不能出现的,一旦出现了,就必须要修改我们编写的代码。
2、数组空指针
举例:
int[] arr = {1,2,3};
arr = null;
System.out.println(arr[0]);
解析:
arr = null这行代码,意味着变量arr将不会在保存数组的内存地址,也就不允许再操作数组了,因此运行的时候会抛出NullPointerException 空指针异常。在开发中,数组的越界异常是不能出现的,一旦出现了,就必须要修改我们编写的代码。
|
|