在以前的学习中,对数组的认识只是简单的数组形式,存储数,但深入学习其实现机理,发现大有文章,下面简单表述一下
一、数组是一个类型,这个从数组的定义说起:
数组的定义有两种方式:以int为例,1.int a[] = ·······, 2.int [] a = ······,第一种定义方法是很多人习惯的,主要是早期的影响,第二种方法才是最适合的定义方法,我们可以从定义看出,定义的是一个int []类型的a变量,这是一个新类型,是一个引用这就比第一种方式:int a[] 明显清晰。
二、说一说数组的初始化方法,初始化方法也有两种,同以int为例,1.int[] a = {1, 2, 3}此为静态初始化方法;
2.int[] a = new int[4]此为动态初始化方法。
三、数组的内存结构:任何一个数组,都不应该只看作是单一的一个数组,应该将其分为两部分思考,堆内存和栈,堆内存是用来存放数组元素的,栈内存是用来存放数组引用变量的,拿动态初始化数组来进行说明:
int[] iArr;
iArr = new int[4];
for(int i = 0; i<iArr.length; i++){
iArr[i] = i + 10;
}
在第一步,int[] a;新建一个数组引用变量a,其会在栈内存中创建一个a
第二步,iArr = new int[4];,在堆内存中新建一个数组元素,iArr并指向数组元素,数组元素初始化为0
第三步,通过for循环给数组元素赋值
一个数组的完整过程就是如此,特需注意的是要将数组一分为二地看待