我们在二维数组中经常搞不清楚arr是什么,arr[0]又是什么,更不用说*arr或者*(arr+0)。
那么今天一篇代码搞定这一堆问题!(注意最后的总结!!!)
#include<stdio.h>
int main()
{
int arr[3][4] = {{1,2,3,4},{4,5,6,7},{6,7,8,9}};
printf("arr的父亲数组地址为:%p,偏移1后为:%p\n",arr,arr+1);
printf("arr[0]子数组地址为:%p,偏移1后为:%p\n",arr[0],arr[0]+1);
printf("arr[0]子数组地址为:%p,偏移1后为:%p\n",*(arr+0),*(arr+0)+1);
int i,j;
for(i=0;i<3;i++){
for(j=0;j<4;j++){
printf("add:0x%p;data:%d\n",&arr[i][j],arr[i][j]);//不用指针的常用遍历数组的方法
printf("add:0x%p;data:%d\n",arr[i]+j,*(arr[i]+j));//arr[i]+j表示数组的首地址
printf("add:0x%p;data:%d\n",*(arr+i)+j,*(*(arr+i)+j));//*(arr+i)+j表示数组的首地址
printf("========================================\n");//即*(arr[i]+j)==*(*(arr+i)+j)==arr[i][j]
}
}
return 0;
}
结果:
arr的父亲数组地址为:000000000061FDE0,偏移1后为:000000000061FDF0
arr[0]子数组地址为:000000000061FDE0,偏移1后为:000000000061FDE4
arr[0]子数组地址为:000000000061FDE0,偏移1后为:000000000061FDE4
add:0x000000000061FDE0;data:1
add:0x000000000061FDE0;data:1
add:0x000000000061FDE0;data:1
========================================
add:0x000000000061FDE4;data:2
add:0x000000000061FDE4;data:2
add:0x000000000061FDE4;data:2
========================================
add:0x000000000061FDE8;data:3
add:0x000000000061FDE8;data:3
add:0x000000000061FDE8;data:3
========================================
add:0x000000000061FDEC;data:4
add:0x000000000061FDEC;data:4
add:0x000000000061FDEC;data:4
========================================
add:0x000000000061FDF0;data:4
add:0x000000000061FDF0;data:4
add:0x000000000061FDF0;data:4
========================================
add:0x000000000061FDF4;data:5
add:0x000000000061FDF4;data:5
add:0x000000000061FDF4;data:5
========================================
add:0x000000000061FDF8;data:6
add:0x000000000061FDF8;data:6
add:0x000000000061FDF8;data:6
========================================
add:0x000000000061FDFC;data:7
add:0x000000000061FDFC;data:7
add:0x000000000061FDFC;data:7
========================================
add:0x000000000061FE00;data:6
add:0x000000000061FE00;data:6
add:0x000000000061FE00;data:6
========================================
add:0x000000000061FE04;data:7
add:0x000000000061FE04;data:7
add:0x000000000061FE04;data:7
========================================
add:0x000000000061FE08;data:8
add:0x000000000061FE08;data:8
add:0x000000000061FE08;data:8
========================================
add:0x000000000061FE0C;data:9
add:0x000000000061FE0C;data:9
add:0x000000000061FE0C;data:9
========================================
总结:
//如果我们把二位数组分为父数组和子数组的话
//即父数组为: arr[0],arr[1],arr[2];
//子数组为:
//arr[0] = {1,2,3,4};
//arr[1] = {4,5,6,7};
//arr[2] = {6,7,8,9};
//arr 二维数组的名字,指向一维数组a[0],表示0行的首地址
//arr[0] == *(arr+0)==*arr 表示0行0列的元素地址
//arr+1 == arr[1] 表示1行地址
//arr[1] == *(arr+1) 表示第1行第0列元素地址,即arr[1][0]的地址
//arr[2] == *(arr+2) 表示第2行第0列元素地址,即arr[2][0]的地址
//arr[1]+2 == *(arr+1)+2 表示第1行第2列元素地址,即arr[1][2]的地址
//*(arr[1]+2) == *(*(arr+1)+2) 表示第1行第2列元素的值,即arr[1][2]的值