剛剛遇到一個很有意思的事蹋嵌,我想給一個字符串動態(tài)分配空間,空間的大小使用sizeof來計算栽烂,然而結(jié)果卻是無論輸入的字符串多大恋脚,sizeof的計算結(jié)果總是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)返回的從命令行獲得的參數(shù)
假如輸入的參數(shù)是AES-128-CBC
船响,那么得到下面結(jié)果:
AES-128-CBC
11
8
輸入?yún)?shù)RC4
躲履,的到下面結(jié)果:
RC4
3
8
原來是對sizeof的理解錯誤,sizeof是一個運算符米诉,計算傳入?yún)?shù)分配得到的空間篷帅,也就是說,假如傳入指針抵窒,計算這個指針?biāo)加玫目臻g叠骑,查閱getopt_long
函數(shù)可以看到定義extern char *optarg;
strlen與sizeof的區(qū)別參考這里,主要卻別如下:
一宙枷、sizeof
sizeof(...)是運算符,在頭文件中typedef為unsigned int卓囚,其值在編譯時即計算好了诅病,參數(shù)可以是數(shù)組、指針蝇棉、類型芥永、對象、函數(shù)等埋涧。
它的功能是:獲得保證能容納實現(xiàn)所建立的最大對象的字節(jié)大小奇瘦。
由于在編譯時計算劲弦,因此sizeof不能用來返回動態(tài)分配的內(nèi)存空間的大小邑跪。實際上,用sizeof來返回類型以及靜態(tài)分配的對象呀袱、結(jié)構(gòu)或數(shù)組所占的空間,返回值跟對象明棍、結(jié)構(gòu)寇僧、數(shù)組所存儲的內(nèi)容沒有關(guān)系。
具體而言兴蒸,當(dāng)參數(shù)分別如下時细办,sizeof返回的值表示的含義如下:
- 數(shù)組——編譯時分配的數(shù)組空間大小笑撞;
- 指針——存儲該指針?biāo)玫目臻g大小(存儲該指針的地址的長度坚踩,是長整型瓤狐,應(yīng)該為4);
- 類型——該類型所占的空間大猩そ凇郁稍;
- 對象——對象的實際占用空間大惺び睢恢着;
- 函數(shù)——函數(shù)的返回類型所占的空間大小财破。函數(shù)的返回類型不能是void。
二靡羡、strlen
strlen(...)是函數(shù)俊性,要在運行時才能計算。參數(shù)必須是字符型指針(char*)趟薄。當(dāng)數(shù)組名作為參數(shù)傳入時典徊,實際上數(shù)組就退化成指針了。
它的功能是:返回字符串的長度卒落。該字符串可能是自己定義的,也可能是內(nèi)存中隨機的也切,該函數(shù)實際完成的功能是從代表該字符串的第一個地址開始遍歷腰湾,直到遇到結(jié)束符NULL。返回的長度大小不包括NULL褂萧。