数组概述
- 数组 (Array),是多个相同类型数据按一定顺序排列的集合,并使用一个名字命名,通过编号的方式对这些数据进行统一的管理。
- 数组的常见概念
- 数组名
- 下标(或索引)
- 元素
- 数组长度
- 数组本身是引用数据类型,而数组中的元素可以是任何数据类型,包括基本数据类型和引用数据类型。
- 创建数组对象会在内存中开辟一整块连续的空间,而数组名引用的是这块连续空间的首地址。
- 数组的长度一旦确定,就不能修改
- 我们可以直接通过下标(或索引)的方式调用指定位置的元素,速度很快,时间复杂度为O(1)。
- 数组的分类:
- 按照维度:一维数组,二维数组,三维数组。。。。
- 按照元素的数据类型分:基本数据类型元素的数组、引用数据类型元素的数组(即对象数组)
一维数组的使用
声明
声明方式:type var[] 或 type[] var
例如:
int a[];
int[] a1;
double c[];
String[] d;// 引用类型元素数组
Java中声明数组时不能指定其长度(数组中的元素个数),例如 int a[4]; 是非法的
初始化
- 动态初始化:数组声明且为数组元素分配空间与赋值的操作分开进行
int[] arr = new int[3];
arr[0] = 3;
arr[1] = 4;
arr[2] = 5;
// ==================
String[] names;
names = new String[3];
names[0] = "1";
names[1] = "2";
names[2] = "3";
- 静态初始化: 在定义数组的同时就为数组元素分配空间并赋值
int[] arr = new int[]{1,2,3};
//或者
int[] arr = {1,2,3};
String[] names = {"1","2","3"};
数组的引用
-
定义并用运算符new为之分配空间后,才可以引用数组中的每个元素;
-
数组元素的引用方式:数组名[数组元素下标]
- 数组元素下标可以是整形常量或整形表达式。如a[3],b[i],c[5*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[] args){
int[] a = new int[5];
System.out.println(a[3]); // a[3]默认值是0
}
}
- 对于基本数据类型而言,默认初始化值各有不同
- 对于引用数据类型而言,默认初始化值为null(注意与0不同!)
一维数组的内存解析
二维数组
对于二维数组的理解,我们可以看成是一维数组array1又作为另一个一维数组array2的元素而存在。其实从数组底层的运行机制来看,其实没有多维数组
//特殊写法
int[] x,y[];
y = new int[3][];
y[0] = new int[3];
y[1] = new int[2];
y[2] = new int[4];
二维数组的内存解析