首先了解:
1.什么是数组
数组(Array)是一种用连续的内存空间存储相同数据类型数据的线性数据结构。
2.写一个int型数组
int[] array = {11,22,33,44,55,66}
此时就会在堆内存开辟一块空间,并且是连续的,又因为是int类型数组,所以会占用四个字节
还有一个栈内存存放的是声明的变量array,array指向的是数组的首地址(内存地址)
数组下标为:0 1 2 3 4 5
想获取数组元素则可以通过索引获取:例如22,则是array[1]、
然后理解:
寻址公式:a[i] = baseAddress + i * dataTypeSize
*baseAddress:数组的首地址
*dataTypeSize:代表数组中元素类型的大小,int型的数据,dataTypeSize=4个字节
此时进行讨论:为什么数组索引从0开始而不从1开始呢?
假如从1开始:寻址公式:a[i] = baseAddress + (i-1) * dataTypeSize
** 注意:对于CPU来说,增加了一个减法指令 **
最终总结为什么:
*在根据数组索引获取元素的时候,会用索引和寻址公式来计算内存所对应的元素数据,寻址公式是:数组的首地址 + 索引乘以存储数据的类型大小
*如果数组的索引从1开始,寻址公式中,就需要增加一次减法操作,对于CPU来说就多了一条指令,性能反而不高了