数组的下标为什么从0开始而不是从1开始

数组是一段连续的空间,要求a[i]就是求它的地址,然后找到它。
在这里插入图片描述

如果从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个内存空间。

发布了1319 篇原创文章 · 获赞 1万+ · 访问量 103万+

猜你喜欢

转载自blog.csdn.net/a1439775520/article/details/104502848