首先用一个实例来说明二维数组的第一维单元存储的是第二维的地址。如下:
三行输出结果是一样的,都是[0][0]元素的地址,也就是说二维数组名和第一维单元都表示数组首址,也是00元素的地址。相当于纵向一维的每个元素存的是第二维的索引地址。
关于字符串有个实例情况说明:char *aa[2]={“abcd”,”ABCD”},显然这是指针数组的模式,这个用法与char a[2][5]是一样的,第一维存的全都是地址。用%s格式输出aa[0],aa[1]就可以输出字符串。如下:
得abcd,efgh。另外注意的是指针的加减是以指针类型长度为单位,不是以字节为单位。
==========================数组首元素地址和整个数组地址===========================
#include "stdio.h"
int main(void){int a[10];
printf("a的大小 = %d\n", sizeof(a));
printf("a = %d\n", a);
printf("a + 1 = %d\n", a + 1);
printf("&a = %d\n", &a);
printf("&a + 1 = %d\n", &a + 1);system("pause");}
结果是
从这组输出我们可以看到几点:
a数组大小是40。因为一个int是4字节,一共10个。
数组a和&a值一样
但是a是数组首元素地址,而&a是整个数组地址。
这个原因也导致另外两个值不同。a+1就是第二个元素地址,偏移4字节
&a+1是相当于偏移整个数组大小,也就是40字节。