1.什么是数组?
数组是一组相同类型元素的集合。
2.数组的创建方式
type_t arr_name [const_n]
type_t 数组的元素类型
arr_name 数组名
const_n 常量表达式,用来指定数组的大小
例如:int arr[2];
char[2+3] ; //这样也行
3.下面代码只能在支持C99标准的编译器上编译:
int n = 19;
scanf("%d",&n);
int arr[n]; //变长数组,不可初始化
在c99之前,数组的大小n必须是常量或者常量表达式;
在c99之后,数组的大小可以是变量,为了支持变长数组,变长数组不可初始化 。(gcc的编译器就支持变长数组)
4.数组的初始化
数组的初始化是指,在创建数组的同时给数组的内容一些合理初始值(初始化)。
int arr1[5] = {1,2,3};
//不完全初始化,剩余元素默认初始化为0
// 1 2 3 0 0
int arr2[5] = {1,2,3,4,5};
// 1 2 3 4 5
int arr12[] = {1,2,3}
//1 2 3
char arr4[5] = {'a','b','c'};
//a b c 0 0
//两个0都是默认的
char arr5[5] = "abc";
//a b c 0 0
//第一个0,是自带的“\0”
//这种初始化arr5比arr4多放一个“\0”,调试监视界面显示一样,但我们要知道
char arr7[] = "abc";
//a b c 0
char arr8[] = {'a','b','c'};
//a b c
5.下标引用操作符 []
int arr[] ={1,2,3,4,5,6};
数组arr初始化实际上是在内存的栈区中申请了一块连续的空间,存放这六个数值,这个空间名叫arr,抽象点,arr这个房子有六个相连的房间,编号从0到5。
那么数组名arr加上操作符和编号—arr[n]; 就可以精准访问数组内的元素。
#include <stdio.h>
int main()
{
int arr[] = {1,2,3,4,5,6};
//计算数组的元素个数
int sz = sizeof(arr)/sizeof(arr[0]);
int i = 0;
//输出数组的内容
for(i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
#include <stdio.h>
int main()
{
int arr[] = { 1,2,3,4,5,6 };
//计算数组的元素个数
int sz = sizeof(arr) / sizeof(arr[0]);
int i = 0;
//打印数组每个元素的地址
for (i = 0; i < sz; i++)
{
printf("&arr[%d] = %p\n", i, &arr[i]);
}
输出数组的内容
//for (i = 0; i < sz; i++)
//{
// printf("%d ", arr[i]);
//}
return 0;
}
2c ,30,34,38,3c,40
'c'是十六进制12,那么这些地址之间差4,就是每个整型元素都占4个字节(int)
随着数组下标的增长,元素的地址,也在有规律的递增。 由此可以得出结论:数组在内存中是连续存放的。