[ 基本难度系数 ]:★★★☆☆
一、基本概念
- 逻辑:一次性定义多个相同类型的变量,并存储到一片连续的内存中
- 示例:
int num[5];
- 语法释义:
- num 是数组名,即这片连续内存的名称
- [5] 代表这片连续内存总共分成5个相等的格子,每个格子称为数组的元素
- int 代表每个元素的类型,可以是任意基本类型,也可以是组合类型,甚至可以是数组
- 初始化:在定义的时候赋值,称为初始化
int num[5] = {100,200,300,400,500}; // ok,正常初始化
int num[5] = {100,200,300,400,500,600}; // 错误,越界了
int num[ ] = {100,200,300}; // OK,自动根据初始化列表分配数组元素个数
int num[5] = {100,200,300}; // OK,只初始化数组元素的一部分
解析:
二、数组元素的赋值和引用
- 存储模式:一片连续的内存,按数据类型分割成若干相同大小的格子
- 元素下标:数组开头位置的偏移量,a[0]引用第1个格子,a[1]引用第2个格子,以此类推
元素下标偏移量
示例代码:
#include <stdio.h>
// 计算数组元素个数 ==
#define CAL_ARR_NUM(A) ( sizeof(A)/sizeof(A[0]) )
// 整个数组的大小/数组一个元素的大小
int main(int argc, char const *argv[])
{
// 初始化
int ibuf[5] = {1,2,3,4,5}; // int型数组的12345和char型数组(字符串)的"12345"是不一样
char sbuf[5] = {"1234"};
// (1)、单个赋值
ibuf[0] = 100;
ibuf[1] = 200;
ibuf[2] = 300;
ibuf[3] = 400;
ibuf[4] = 500;
// ibuf[5] = 600; // 到此为止,后面的内存是非法区域(也就你没有权限对其更改)
// (2)、循环赋值
long unsigned int ret = CAL_ARR_NUM(ibuf);
printf("数组的元素个数为 = %lu\n", ret);
for (int i = 0; i < ret; i++)
{
ibuf[i] = (i+1)*100;
printf("buf[%d] = %d\n", i, ibuf[i]);
}
return 0;
}
三、其它类型的数组
(1)、字符数组
- 概念:专门存放字符的数组,称为字符数组
- 初始化与元素引用:
- 示例代码:
#include <stdio.h>
#include <string.h>
#include <strings.h>
// 计算数组元素个数 ==
#define CAL_ARR_NUM(A) ( sizeof(A)/sizeof(A[0]) )
// 整个数组的大小/数组一个元素的大小
int main(int argc, char const *argv[])
{
// (1)、字符数组
// 1、字符串数组初始化
char s1[5] = {'a', 'b', 'c', 'd', 'e'}; // 字符数组,不是字符串(末尾没有'\0')
char s2[5] = {'a', '