借助()函数
# include
int main(void)
{
int a[10] = {0};
printf("sizeof(a) = %d\n", sizeof(a));
return 0;
}
(a) = 40,数组a为int类型,每个元素占用4个字节,所以长度为10的数组在内存中占用的字节数为40,总字节数除以字节数一个元素所占的位置就是数组的长度,如下面的程序:
# include
int main(void)
{
int a[10] = {0};
// 计算数组中数据长度 :
// 所有数据的字节数除以一个数据的字节数即为数据的个数 :
//int length = sizeof(arr) / sizeof(int); //这句也可以
int cnt = sizeof(a) / sizeof(a[0]);
printf("cnt = %d\n", cnt);
return 0;
}
输出是:
碳纳米管 = 10
这样,无论数组是递增还是递减元素,(a)/(a[0])都能自动求出数组的长度。 需要注意的是,它计算的是数组的总长度,而不是数组中存储的有意义数据的数量。 例如定义一个int类型的数组:
int a[10] = {1, 2, 3, 4, 5};
我们只初始化了 5 个元素,但 (a)/(a[0]) 的计算结果为 10,而不是 5。换句话说,我们无法通过 (a)/(a[0]) 找出数组中有多少有意义的数据)。
参数传递
无法通过将数组名称参数传递给子例程来获取数组的长度。
#include
void test(int arr[])
{
int length = 0;
length = sizeof(arr) / sizeof(int);
printf("test_数组的总字节数为: %d\n",sizeof(arr));
printf("test_数组的长度为: %d\n",length);
}
int main()
{
// 定义一个整型数组, 并进行初始化赋值9个数据 :
int arr[] = {1,2,3,4,5,6,7,8,9};
int length = 0;
// 计算数组中数据长度 :
// 所有数据的字节数除以一个数据的字节数即为数据的个数 :
length = sizeof(arr) / sizeof(int);
printf("main_数组的长度为: %d\n",length);
test(arr);
return 0;
}
代码分析:
当数组作为实参传递给另一个函数时,另一个函数的形参就相当于一个指针变量,因为当使用数组名作为实参时,将数字的首地址作为实际参数,所以在测试函数输出中
(arr)实际上得到的是一个整型数组的长度(占用的字节数),所以结果是8,然后除以int(4)占用的字节数,结果是2。(64位)。 1 在 32 位机器上。
因此,要获取数组的长度,只能在数组定义所在的代码区使用上述方法才能达到效果。