二维数组和二维数组名:
对于一位数组我们认识到其数据元素在内存中是按线性顺序依次排列的,且一维数组名的值是一个指针常量。那么二维数组在内存中又是怎么存储的,其数组名又有什么含义呢?
定义一个二维数组:
int Arr [3] [4] = {{1,1,1,1},{2,2,2,2},{3,3,3,3},{4,4,4,4}};
我们可以将一个二维数组看做是一个其中元素为数组的一个一位数组,也就是说二维数组第一维的元素实际上是另一个数组。所以数组名arr是一个指向一个包含有4个整形元素的数组的指针,即数组指针常量。
#include<stdio.h>
int main() {
double a[2][3];
printf("%d\n",*(&a+1)-a);//行数 (取二维数组名的地址进行加一操作,每次加一移动的是行数个单位也就是2行)
printf("%d\n",*a);//第一行 行首地址
printf("%d\n",*(a+1));//第一行加一也就是来到第二行(这里行加一每次移动是列数个单位地址)
printf("%d\n",*(a+1)-*a);//列数 (第二行的行首地址减去第一行的行首地址得到列数个地址单位)
printf("%d\n",**(&a+1)-*a);//数组元素个数(取二维数组名地址加一后解两次地址得到行地址,两个行地址相减得到的是二维数组所有元素的个数)(取二维数组名a的地址得到加一跳过的是整个二维数组元素个数个地址)
return 0;
}
**(&a+1)-*a