文章目录
定义
- 数组(Array),是多个相同类型数据按一定顺序排列的集合,并使用一个名字命名,并通过编号的方式对这些数据进行统一管理。
- 常见概念
- 数组名
- 下标(或索引)
- 元素
- 数组的长度
概述
- 数组本身是引用数据类型,而数组中的元素可以是任何数据类型,包括基本数据类型和引用数据类型。
- 创建数组对象会在内存中开辟一整块连续的空间,而数组名中引用的是这块连续空间的首地址。
- 数组的长度一旦确定,就不能修改。
- 可以直接通过==下标(或索引)==的方式调用指定位置的元素,速度很快。
分类
按照维度:可以分为一维数组、多维数组。
一维数组
一维数组声明
Java中声明数组时不能指定其长度,如 int a[5]; 是非法的。
// 两种格式
type var[];
type[] var2;
//举例
int a[];
int[] a1;
double b[];
//引用类型变量数组
String[] c;
一维数组初始化
- 动态初始化
- 数组声明且为数组元素分配空间与赋值的操作分开进行。
// 声明
int[] arr = new int[3];
// 初始化
arr[0] = 3;
arr[1] = 9;
arr[2] = 8;
// 声明
String names[];
// 初始化
names = new String[3];
names[0] = “钱学森”;
names[1] = “邓稼先”;
names[2] = “袁隆平”;
- 静态初始化
- 在定义数组的同时就为数组元素分配空间并赋值。
int arr[] = new int[]{3,9,8};
int[] brr = {3,9,8};
String names[] = {
"李四光","茅以升","华罗庚"
}
一维数组使用
-
数组元素的引用
- 定义数组并new为其分配空间后,才可以引用数组中的元素。
- 引用方式:数组名[数组元素下标]
- 数组元素下标可以是整型常量或整型表达式。
- 如a[3] , b[i] , c[6*i];
- 数组元素下标从0开始;长度为n的数组合法下标取值范围: 0 —>n-1。
- 如int a[]=new int[3];
- 可引用的数组元素为 a[0]、a[1]、a[2]
- 每个数组都有一个属性length指明它的长度。
- 如:a.length 指明数组a的长度(元素个数)
- 数组一旦初始化,其长度是不可变的。
-
- 数组是引用类型,它的元素相当于类的成员变量,因此数组一经分配空间,其中的每个元素也被按照成员变量同样的方式被隐式初始化。
public class Test {
public static void main(String argv[]){
int a[]= new int[5];
System.out.println(a[3]); //a[3]的默认值为0
char a[] = new char[3];
System.out.println("---" + a[0] + "***"); //--- ***
System.out.print(0 == a[0]); //true
}
}
- 内存解析
JVM内存结构图如下
int arr[] = new int[]{1,2,3};
int arr2[] = arr;
- 首先在栈内存中创建arr局部变量
- 在堆内存中开辟一个连续空间,共3块,首地址假设为0x34ab。
- 栈内存中的arr存值设为0x34ab,即指向堆内存中开辟空间的首地址,此时默认值均为0。
- 分别给堆内存中arr[0],arr[1],arr[2] 赋值为1,2,3。
- 将数组arr的值即堆内存数据的首地址0x34ab赋值给arr2,两个堆内存中的变量均指向堆内存中同一个地址,这种方式不是数组的复制。
多维数组
对于二维数组,可以看成是一维数组array1作为另一个一维数组array2的元素而存在。从数组底层的运行机制来看,其实没有多维数组。
多维数组声明
// 两种格式
type var[][];
type[][] var2;
//举例
int a[][];
int[][] a1;
double b[][];
//引用类型变量数组
String[][] c;
多维数组初始化
当使用new 来创建多维数组时,不必指定每一维的大小,但要指定最左边的维的大小。
- 动态初始化
/*
* 格式一
* 定义了名称为arr的二维数组,二维数组中有3个一维数组
* 每个一维数组中有2个元素
* 一维数组的名称分别为arr[0], arr[1], arr[2]
*/
int[][] arr = new int[3][2];
arr[0][1] = 78;
/*
* 格式二
* 定义了名称为arr的二维数组,二维数组中有3个一维数组
* 每个一维数组都是默认初始化值null (注意:区别于格式1)
*/
int[][] arr = new int[3][];
arr[0] = new int[3];
arr[1] = new int[1];
arr[2] = new int[2];
//非法
int[][]arr = new int[][3];
- 静态初始化
/*
* 定义一个名称为arr的二维数组,二维数组中有三个一维数组
* 每个一维数组中具体元素也都已初始化
*
* 第一个一维数组 arr[0] = {3,8,2};
* 第二个一维数组 arr[1] = {2,7};
* 第三个一维数组 arr[2] = {9,0,1,6};
*
* 第三个一维数组的长度表示方式:arr[2].length;
*/
int[][] arr = new int{
{3,8,2},
{2,7},
{9,0,1,6}
};
int arr1[][] = {
{3,8,2},
{2,7},
{9,0,1,6}
};
- 注意
- 特殊写法情况:int[] x,y[]; x是一维数组,y是二维数组。
- Java中多维数组不必都是规则矩阵形式
多维数组使用
多维数组的数组名如arr,直接输出是第一个维度数组的首地址,arr.length是第一个维度数组的长度。
int[][] arr = new int [4][];
System.out.println(arr); // [[I@15db9742
arr[0] = new int[3];
System.out.println(arr[0]); // [I@6d06d69c
System.out.println(arr[1]); // null
System.out.println(arr[0][0]); // 0
System.out.println(arr.length); // 4
System.out.println(arr[0].length); // 3
![image-20200322155443820](https://i-blog.csdnimg.cn/blog_migrate/bd3648074a9e46c38f31314aaaf9a4e6.png)
数组例题
Arrays工具类
定义在java.util包下,提供了很多操作数组的方法。
方法 | 描述 |
---|---|
boolean equals(int[] a,int[] b) | 判断两个数组是否相等。 |
String toString(int[] a) | 输出数组信息。 |
void fill(int[] a,int val) | 将指定值填充到数组之中 |
void sort(int[] a) | 对数组进行排序。 |
int binarySearch(int[] a,int key) | 对排序后的数组进行二分法检索指定的值。 |
import java.util.Arrays;
/*
* java.util.Arrays:操作数组的工具类,里面定义了很多操作数组的方法
*/
public class ArraysTest {
public static void main(String[] args) {
//1.boolean equals(int[] a,int[] b):判断两个数组是否相等。
int[] arr1 = new int[]{1,2,3,4};
int[] arr2 = new int[]{1,3,2,4};
boolean isEquals = Arrays.equals(arr1, arr2);
System.out.println(isEquals);
//2.String toString(int[] a):输出数组信息。
System.out.println(Arrays.toString(arr1));
//3.void fill(int[] a,int val):将指定值填充到数组之中。
Arrays.fill(arr1,10);
System.out.println(Arrays.toString(arr1));
//4.void sort(int[] a):对数组进行排序。
Arrays.sort(arr2);
System.out.println(Arrays.toString(arr2));
//5.int binarySearch(int[] a,int key)
int[] arr3 = new int[]{-98,-34,2,34,54,66,79,105,210,333};
int index = Arrays.binarySearch(arr3, 210);
if(index >= 0){
System.out.println(index);
}else{
System.out.println("未找到");
}
}
}
数组使用常见异常
数组脚标越界异常(ArrayIndexOutOfBoundsException)
访问到了数组中的不存在的脚标时发生。
int[] arr = new int[2];
System.out.println(arr[2]);
System.out.println(arr[-1]);
空指针异常(NullPointerException)
arr引用没有指向实体,却在操作实体中的元素时。
int[] arr = null;
System.out.println(arr[0]);