本文主要是介绍C语言获取数组长度中的诡异现象,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
借助sizeof()函数
# include <stdio.h>
int main(void)
{ int a[10] = {0};printf("sizeof(a) = %d\n", sizeof(a));return 0;
}
sizeof(a) = 40 ,数组 a 是 int 型的,每个元素占 4 字节,所以长度为 10 的数组在内存中所占的字节数就是 40。而总的字节数除以一个元素所占的字节数就是数组的长度,如下面这个程序:
# include <stdio.h>
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;
}
输出结果是:
cnt = 10
这样不管数组是增加还是减少元素,sizeof(a)/sizeof(a[0]) 都能自动求出数组的长度。需要注意的是,它求出的是数组的总长度,而不是数组中存放的有意义的数据的个数。比如定义一个int型的数组:
int a[10] = {1, 2, 3, 4, 5};
我们只初始化了五个元素,但是 sizeof(a)/sizeof(a[0]) 求出的是 10,而不是 5。换句话说,我们无法通过 sizeof(a)/sizeof(a[0]) 求出数组中有多少个有意义的数据。
参数传递
通过传递数组名参数到子函数中,以获得数组长度是不可行的。
#include<stdio.h>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;
}
代码分析 :
当将数组作为实参传递到另一个函数中时, 另一个函数的形参相当于一个指针变量, 因为将数组的名作为实参时, 就是将数字的首地址作为实参, 所以在test函数中输出的
sizeof(arr)其实得到的是一个整型数组的长度(所占的字节数), 所以结果是8, 再用其除以int所占的字节数(4), 结果就是2 。(64位) 。32位机上是1。
因此,获得数组长度,只能在数组定义所在的代码区中,采用以上方法,才可以达到效果。
这篇关于C语言获取数组长度中的诡异现象的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!