详解sizeof在自定义函数中不能正常工作

1、在main函数中,sizeof是可以正常工作的,比如:

int main()
{
	int n[5];
	printf("input: \n");
	int i ;
	for(i = 0; i < 5; i++)
	{
		scanf("%d",n + i);
	}
	int len = sizeof(n)/sizeof(n[0]);
	printf("%d\n",len);
	return 0;
}

2、但是在自定义函数中就不可以了,如下:

    

#include <stdio.h>
void print_1(int n[])
{
	int i;
	int len = sizeof(n)/sizeof(n[0]);
	printf("len : %d\n",len);
	for(i  = 0; i < len; i++)
	{
		printf("%d",n[i]);
	}
	
	printf("\n");
}
int main()
{
	int n[5];
	printf("input: \n");
	int i ;
	for(i = 0; i < 5; i++)
	{
		scanf("%d",n + i);
	}

	print_1(n);
	printf("\n");
	return 0;
}

3、至于原因以及解决方法感觉有篇博客说的比较好

原因在于:第一,在c中,数组在作为参数的时候就退化为指针,对一个地址来取大小呢,如果是32位系统的话即为4,如果是64位系统的话为8,所以呢,在函数中sizeof获取的是指针的长度而不是数组的长度。第二呢,在函数中,sizeof的处理时间的在编译期,也就是说对于动态生成的数组大小是不能用sizeof来算出来的。

4、

解决办法:

第一种办法:

把数组作为参数传入到数组的同时呢,也传入该数组的长度进去。不过该办法需要在函数外获取该数组的长度才传进去,略显麻烦。比如讲上述代码的打印函数的函数名print(int *n) ; 改成print(int *n ,int len);其中len代表数组n的长度

第二种,采用宏定义,但是这种方法个人感觉显得有些啰嗦

第三种:C++可以用vector等容器避免大部分数组的操作,对于字符数组也有string可以替代,也有可以传递数组大小的奇迹淫巧。如果你需要计算数组长度的函数,可以使用宏定义 或者 如果是C++,也用相应的模板技巧,这比宏定义安全。

template <size_t N>
long calc(long (&array)[N]) // 利用模板传递参数 array是数组的引用
{
    long res = 0L;
 
    for (size_t i = 0;i < N;i ++) {
        res += array[i];
    }
 
    return res;
}
 
int main()
{
    long longarr[] = {1, 23, 4, 45, 46, 57,};
 
    long sum = calc(longarr);
}
 

总结:在写这些小的程序时,若没有特殊要求,直接将数组的长度确定,就不需要这么麻烦了

猜你喜欢

转载自blog.csdn.net/xiaonan153/article/details/81411600