一维数组、二维数组的大小、长度与偏移

一维数组大小与长度

int a[10];

1 数组的大小

int size = sizeof(a) = 40;

2数组的长度

int len = sizeof(a) /sizeof(int) = 10

3数组的偏移

首先数组名代表首个元素的地址,要注意数组名是一个常量,不能被赋值,a == &a[0] == 01(假设数组的起始地址为01)
a + 1 == &a[0] + 1 == 05 地址加一跳过一个整形元素,即跳过4个字节
&a + 1 = 0x01 + 10 * 4 = 41 虽然&a(二级指针)、a(一级指针) 表示的起始地址相同,但a表示数组首个元素的地址,&a表示整个数组的地址,数组的地址加1将跳过整个数组,即跳过4 * 10 个字节

二维数组大小与长度

int a[3][4]

1 数组的大小

int size = sizeof(a) = 4 * 3 * 4 = 48;

2 数组的行

sizeof(a) / sizeof(a[0]) = 48 / 4 * 4 = 3 (数组的大小除以每一行的大小得到行数)

3 数组的列

sizeof(a[0]) / sizeof(int) = 16 / 4 = 4 (每一行的大小除以每一个元素的大小得到列)

4 数组的偏移

a[0] 代表第0行的数组名 ,代表首个元素的地址,即等价于第0行第0个元素的地址 a[0] = &a[0][0] (一级指针)
a 代表二维数组的数组名,代表首行的地址, 即 a = &a[0](二级指针)
&a 代表整个二维数组的地址(三级指针)
a[0] + 1 = &a[0][0] + 1 跳过一个整形元素
a + 1 = &a[0] + 1 跳过一行
&a + 1 跳过整个数组

你可能感兴趣的:(数组)