詳解C語言中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);
}

總結:在寫這些小的程序時,若沒有特殊要求,直接將數組的長度確定,就不需要這麼麻煩瞭

到此這篇關於詳解C語言中sizeof如何在自定義函數中正常工作的文章就介紹到這瞭,更多相關C語言sizeof內容請搜索LevelAH以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持LevelAH!

推薦閱讀: