我们所说的数组元素个数是指总元素个数
例如:
arr[10]中有10个元素
arr[3][4]中有3X4=12个元素
那么怎么能求出这个个数给计算机呢?
对于一维数组
#include <stdio.h>
int main()
{
int arr[10] = { 0 };
int sz = sizeof(arr) / sizeof(arr[0]);
printf("%d\n", sz);
return 0;
}
这个时候我们计算出来这个一维数组的元素个数如下:![在这里插入图片描述](https://img-blog.csdnimg.cn/20210124102523489.png
对于二维数组
#include <stdio.h>
int main()
{
int arr[3][4] = { 0 };
int sz = sizeof(arr) / sizeof(arr[0][0]);
printf("%d\n", sz);
return 0;
}
程序运行结果如下:
此时我们来对上述程序中的sz做一个解释说明。
1.首先我们说对于一维数组,arr[0]代表首元素,对二维数组来说arr[0][0]表示首元素。
2.其次,数组名表示首元素地址,但有两个例外
(1)sizeof(数组名)时,数组名表示的是整个数组,不是首元素地址,sizeof(数组名)计算的是整个数组的大小。
(2)&数组名时(&表示取地址符),数组名表示整个数组,这里取出的是整个数组的地址。
除此之外,所有的数组名都是首元素地址。
3.最后我们用整个数组元素去除以数组的首元素可以得到数组的元素个数。
感谢阅读。