strlen與sizeof

剛剛遇到一個很有意思的事,我想給一個字符串動態分配空間,空間的大小使用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。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容