4.7 数组简介

C语言学习栏目目录


在许多程序中,数组很重要。数组可以作为一种储存多个相关项的便利方式。我们在第10章中将详细介绍数组,但是由于循环经常用到数组,所以在这里先简要地介绍一下。

数组(array)是按顺序储存的一系列类型相同的值,如10个char类型的字符或15个int类型的值。整个数组有一个数组名,通过整数下标访问数组中单独的项或元素(element)。例如,以下声明:

float a[20];

声明a是一个内含20个元素的数组,每个元素都可以储存float类型的值。数组的第1个元素是a[0],第2个元素是a[1],以此类推,直到a[19]。注意,数组元素的编号从0开始,不是从1开始。可以给每个元素赋float类型的值。例如,可以这样写:

a[5] = 32.54;
a[6] = 1.2e+21;

实际上,使用数组元素和使用同类型的变量一样。例如,可以这样把值读入指定的元素中:

scanf("%f", &a[4]); // 把一个值读入数组的第5个元素

这里要注意一个潜在的陷阱:考虑到影响执行的速度,C 编译器不会检查数组的下标是否正确。下面的代码,都不正确:

debts[20] = 88.32;   // 该数组元素不存在
debts[33] = 828.12;  // 该数组元素不存在

编译器不会查找这样的错误。当运行程序时,这会导致数据被放置在已被其他数据占用的地方,可能会破坏程序的结果甚至导致程序异常中断。

数组的类型可以是任意数据类型。

int nannies[22]; /* 可储存22个int类型整数的数组 */
char actors[26]; /* 可储存26个字符的数组 */
long big[500];  /* 可储存500个long类型整数的数组 */

我们在(第五 字符串和格式化输入/输出)中讨论字符串,可以把字符串储存在char类型的数组中(一般而言,char类型数组的所有元素都储存char类型的值)。如果char类型的数组末尾包含一个表示字符串末尾的空字符\0,则该数组中的内容就构成了一个字符串(见下图)。

用于识别数组元素的数字被称为下标(subscript)、索引(indice)或偏移量(offset)。下标必须是整数,而且要从0开始计数。数组的元素被依次储存在内存中相邻的位置,如下图

 

©️2020 CSDN 皮肤主题: 猿与汪的秘密 设计师:上身试试 返回首页