为什么数组的下标从 0 开始?

开发 前端
数组是一组连续内存空间存储的具有相同类型的数据,整个排列像一条线一样,是一种线性表数据结构。

[[410309]]

本文转载自微信公众号「微观技术」,作者Tom哥  。转载本文请联系微观技术公众号。

首先,我们来复习下数组的定义

数组是一组连续内存空间存储的具有相同类型的数据,整个排列像一条线一样,是一种线性表数据结构。

那么,问题来了,数组的下标为什么要从 0 开始?从 1 开始行不行?

端好你的小茶杯,开始进入正题

数组之所以广泛使用,是因为它支持随机访问。

什么叫随机访问?

数据在内存中都是按顺序存放的,通过下标直接触达到某一个元素存放的位置。

公式:

  • Tom哥[n] = base_address + n * data_size
    • base_address,表示数组的首地址
    • n,表示偏移量
    • data_size,表示数组类型的字节数
  1. ① 读取上面数组的 【0】位置的 `微` 
  2. ② 读取上面数组的 【9999】位置的 `注` 
  3.  
  4. 由于基于计算的内存地址读取数据,上面两种情况的耗费的时间是一样,时间复杂度为 O(1) 

注意:想要使用随机访问,一定要满足两个条件: 1、连续的内存空间 2、相同类型的数据

知识补充:

与随机访问对应的是顺序访问

顺序访问:链表在内存中不是按顺序存放的,而是通过指针连在一起,访问某一元素,必须从链头开始顺着指针才能找到某一个元素。

突然,一个奇怪的念头冒了出来,假如我们将数组的首个下标从 1 开始 ,会怎么样?

我们读取 下标为n 的数据

公式:

  • Tom哥[n] = base_address + (n-1) * data_size

与上面的公式的区别,多了一次 n-1 操作

虽然也能读取数组中的值,但是多了一次减法的指令运算。

数组是一个最基础、最简单的数据结构。要知道我们的上层API内部很多都会依赖于数组,而互联网应用又讲究一个高并发,一言不合就是千万级QPS,如此高频的访问量,这个冗余的减运算 就会放大无数倍,产生巨大的性能损耗。

这样说,可能大家感受不一定明显!!!

”我在马路边捡到一分钱,把它交到警察叔叔手里边“。现在再有一分钱,你还会捡吗,估计很多人都看不上眼,但要是全国人民每人给你一分钱呢

14亿 * 1分钱 = 1400万 人民币

是不是可以立马辞职,回家躺平了!

 

量变引发质变,做软件开发,我们一定要考虑将性能优化到极致,骨子里透着工匠精神。

 

责任编辑:武晓燕 来源: 微观技术
相关推荐

2014-02-01 21:25:08

Python数组

2023-11-04 16:26:18

C语言数组

2022-05-24 08:31:05

C语言检查数组

2020-12-14 08:00:31

计算机计数程序

2024-02-06 09:55:33

框架代码

2015-05-29 11:14:31

程序员开始看书

2023-03-29 08:52:58

视觉Vue组件库

2022-11-26 00:34:57

数组Java程序

2022-08-31 14:24:03

数字化转型小程序平台

2024-06-07 09:13:23

2022-08-12 21:40:41

FedoraCC0许可证

2019-04-22 09:58:25

C语言Web操作系统

2016-11-21 15:22:47

GitHub操作开源

2018-05-23 15:20:08

区块链数字货币比特币

2019-01-29 14:29:03

微服务路由

2013-01-22 09:35:27

Hadoop存储

2023-03-01 07:37:10

数组链表性能

2017-02-07 09:37:46

2011-07-03 18:28:13

网站优化

2017-05-08 14:27:49

PHP框架函数框架
点赞
收藏

51CTO技术栈公众号