int Arr[4][5];
for(int i = 0; i < 4; i++)
{
for(int j = 0; j < 5; j++)
{
Arr[i][j] = i*5 + j;
}
}
printf("*Arr[0] = %d \n",*Arr[0]);
printf("*Arr = %d \n",*Arr);
printf("&Arr[0][0] = %d \n",&Arr[0][0]);
printf("&Arr[0] = %d \n",&Arr[0]);
printf("Arr = %d \n",Arr);
**Arr 才得到Arr[0] 两次解引用

Arr+1 和 Arr[0]+1
Arr是二维数组的首地址
Arr[0]是二维数组第一行的首地址
他们的值相同 但是修饰的目标类型不同
Arr这个指针修饰的是 (int *)[5] 一次跨越20字节
而Arr[0]这个指针修饰的是int 一次跨越4个字节
本文详细探讨了二维数组的内存布局以及指针在数组操作中的应用。通过示例代码解释了`Arr`和`Arr[0]`在内存表示上的差异,指出`Arr`是一个指向整型指针数组的指针,而`Arr[0]`是一个指向整型的指针,它们在地址值相同但修饰目标类型不同。同时,文章强调了指针解引用及地址运算在数组访问中的重要性。
1464

被折叠的 条评论
为什么被折叠?



