1、首先要搞清楚一个东西——计算机如何访问数组元素?
计算机其实是通过数组的下标来访问数组元素。
2、数组的下标从1开始不是更符合人们平时的计数和排序习惯吗?
(1)其实这就是很多人经常会有的一个固定思维,原因就是没有深入去了解和认识数组下标是什么含义,以为就是一个简单的序号而已啦,然而实际上并不是这样的。
原理剖析:计算机通过数组下标来访问数组元素,是有这么一个计算内存地址的公式的:a[i]_address = base_address + i*data_type_size,意思就是数组中第i个元素的地址(a[i]_address)等于计算机给这个数组分配的首地址(base_address)加上第i个元素的字节大小( i*data_type_size)。
实质含义:从上面这个公式来看,数组下标最精确的意思是偏移量,a[0]的偏移量为0,地址即为计算机分配的首地址,以此类推。
(2)做个假设:数组的下标从1开始,也可以写计算内存地址的公式,则为:“a[i]_address = base_address + (i-1)*data_type_size”,此时不难发现从1开始比从0开始多了一次运算(i-1),对于CPU来说,每次随机访问就要多发一条指令,很划不来的。