剛剛遇到一個很有意思的事,我想給一個字符串動態分配空間,空間的大小使用sizeof來計算,然而結果卻是無論輸入的字符串多大,sizeof的計算結果總是8,換用strlen就可以正常使用了,代碼如下:
62 printf("%s\n",optarg);
63 printf("%d\n",(int)strlen(optarg));
64 printf("%d\n",(int)sizeof(optarg));
optarg是 getopt_long(argc, argv, "m:a:k:v:i:o:f:h", arg_options, &option_index)返回的從命令行獲得的參數
假如輸入的參數是AES-128-CBC
,那么得到下面結果:
AES-128-CBC
11
8
輸入參數RC4
,的到下面結果:
RC4
3
8
原來是對sizeof的理解錯誤,sizeof是一個運算符,計算傳入參數分配得到的空間,也就是說,假如傳入指針,計算這個指針所占用的空間,查閱getopt_long
函數可以看到定義extern char *optarg;
strlen與sizeof的區別參考這里,主要卻別如下:
一、sizeof
sizeof(...)是運算符,在頭文件中typedef為unsigned int,其值在編譯時即計算好了,參數可以是數組、指針、類型、對象、函數等。
它的功能是:獲得保證能容納實現所建立的最大對象的字節大小。
由于在編譯時計算,因此sizeof不能用來返回動態分配的內存空間的大小。實際上,用sizeof來返回類型以及靜態分配的對象、結構或數組所占的空間,返回值跟對象、結構、數組所存儲的內容沒有關系。
具體而言,當參數分別如下時,sizeof返回的值表示的含義如下:
- 數組——編譯時分配的數組空間大小;
- 指針——存儲該指針所用的空間大小(存儲該指針的地址的長度,是長整型,應該為4);
- 類型——該類型所占的空間大小;
- 對象——對象的實際占用空間大小;
- 函數——函數的返回類型所占的空間大小。函數的返回類型不能是void。
二、strlen
strlen(...)是函數,要在運行時才能計算。參數必須是字符型指針(char*)。當數組名作為參數傳入時,實際上數組就退化成指針了。
它的功能是:返回字符串的長度。該字符串可能是自己定義的,也可能是內存中隨機的,該函數實際完成的功能是從代表該字符串的第一個地址開始遍歷,直到遇到結束符NULL。返回的長度大小不包括NULL。