詳解C語言中sizeof如何在自定義函數(shù)中正常工作
1、在main函數(shù)中,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、但是在自定義函數(shù)中就不可以了,如下:
#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中,數(shù)組在作為參數(shù)的時候就退化為指針,對一個地址來取大小呢,如果是32位系統(tǒng)的話即為4,如果是64位系統(tǒng)的話為8,所以呢,在函數(shù)中sizeof獲取的是指針的長度而不是數(shù)組的長度。第二呢,在函數(shù)中,sizeof的處理時間的在編譯期,也就是說對于動態(tài)生成的數(shù)組大小是不能用sizeof來算出來的。
4、解決辦法
第一種辦法
把數(shù)組作為參數(shù)傳入到數(shù)組的同時呢,也傳入該數(shù)組的長度進去。不過該辦法需要在函數(shù)外獲取該數(shù)組的長度才傳進去,略顯麻煩。比如講上述代碼的打印函數(shù)的函數(shù)名print(int *n) ; 改成print(int *n ,int len);其中l(wèi)en代表數(shù)組n的長度
第二種辦法
采用宏定義,但是這種方法個人感覺顯得有些啰嗦
第三種辦法
C++可以用vector等容器避免大部分數(shù)組的操作,對于字符數(shù)組也有string可以替代,也有可以傳遞數(shù)組大小的奇跡淫巧。如果你需要計算數(shù)組長度的函數(shù),可以使用宏定義 或者 如果是C++,也用相應的模板技巧,這比宏定義安全。
template <size_t N> long calc(long (&array)[N]) // 利用模板傳遞參數(shù) array是數(shù)組的引用 { 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); }
總結:在寫這些小的程序時,若沒有特殊要求,直接將數(shù)組的長度確定,就不需要這么麻煩了
到此這篇關于詳解C語言中sizeof如何在自定義函數(shù)中正常工作的文章就介紹到這了,更多相關C語言sizeof內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vscode+qt5+cmake編譯調(diào)試過程解析
這篇文章主要介紹了vscode+qt5+cmake編譯調(diào)試過程解析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03C++中constexpr與函數(shù)參數(shù)轉(zhuǎn)發(fā)的操作方法
constexpr是c++11引入的關鍵字,c++11的constexpr的函數(shù)中只是支持單句代碼,c++14限制放寬,可以在里邊寫循環(huán)及邏輯判斷等語句,本文探討關于constexpr的函數(shù)中參數(shù)的現(xiàn)象,以及如果參數(shù)是constexpr如何做轉(zhuǎn)發(fā),感興趣的朋友一起看看吧2024-02-02