第一阶段:
int a[3][4];
1. 数组名a 表示行地址,a+1表示从一行跳到下一行,a[0]->a[1],偏移了4*4 = 16个字节
2. 子数组名a[0]表示列地址,a[0]+1表示a[0][0]->a[0][1],偏移了4个字节
3. a等价于&a[0](注意a[0]也是地址,等价&a[0][0])
4. a[1]等价&a[1][0]
图示:
第二阶段:
int a[3][4];
1. *a 的结果为a[0],a[0]实质是a[0][0]的地址值,*a == *(&a[0]) == a[0] == &a[0][0]
2. a[1] == *a + 1 ,a[0]地址偏移4个字节
3.*a[0]是a[0][0]的值,a[0]本质也是一个数组名,表示一个地址,等价于&a[0][0]
4. a[1][1] == *(a+1) + 1
第三阶段:
应用:遍历二维数组中每个元素的地址和每个元素的值
tip:若想定义一个指针变量指向a的列数组: int (*p)[4] = a;
下面需要用到a的地方即可用p替代使用。
三种不同的遍历方法
源码:
#include <stdio.h>
/*遍历二维数组中每个元素的地址和每个元素的值*/
int main()
{
int a[3][4] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};
int i,j;
// 若想定义一个指针变量指向a的列数组:
// int (*p)[4] = a;下面需要用到a的地方即可用p替代使用
for(i = 0; i < 3; i++)
{
for(j = 0; j < 4; j++)
{
// 以下三条输出结果一样,都是遍历二维数组中每个元素的地址和每个元素的值
//法一:
//printf("address1:0x%p,data:%d \n", &a[i][j], a[i][j] );
//法二:
//printf("address2:0x%p,data:%d \n", a[i]+j, *(a[i]+j) );
//法三:
printf("address3:0x%p,data:%d \n", *(a+i)+j, *(*(a+i)+j) );
printf("==================================\n");
}
}
}
输出: