淘先锋技术网

首页 1 2 3 4 5 6 7

数组是一段连续的空间,要求a[i]就是求它的地址,然后找到它。

9c1ee98fef33ab0a4b4285a7cf365f36.png

如果从0开始,则a[i]的地址= 首地址 + i*每个数据所占的长度;

如果从1开始,则a[i]的地址= 首地址 + (i-1)*每个数据所占的长度。

是不是前一种更好计算呢。

再举个例子:

1、数组在内存中申请是,所申请的内存是一段连续的内存地址;

2、例:int[] a=new int[3];申请一段:int 数据类型的数组,a 为变量,数组长度为:[3];

3、这个数组所申请的内存地址是连续的

(假设所申请的:第一个内存地址为:1008,第二个为:1009,第三个为:1010);

但我们只知道:一、变量:a,它只拿到第一个内存地址1008;二、它的数组空间为3个;

4、a[0]——把a拿到的内存地址:1008 + 0 = 1008 (指向第一个内存地址);

a[1]——把a拿到的内存地址:1008 + 1 = 1009 (指向第二个内存地址);

a[2]——把a拿到的内存地址:1008 + 2 = 1010 (指向第三个内存地址);

所以:数据下标从 [0] 开始的意义也在于此!(当然,这是理解版的)。

(备注):如果你写a[3],它就报错了,越界错误,因为你只申请了3个内存空间。