Sizeof與Strlen的區別與聯繫

一、sizeof

(1)sizeof()是運算符,在頭文件中typedef爲unsigned int,其值在編譯時即計算好了,參數能夠是數組、指針、類型、對象、函數等。數組

(2)功能:得到保證能容納實現所創建的最大對象的字節大小。函數

(3)因爲在編譯時計算,所以sizeof不能用來返回動態分配的內存空間的大小。實際上,用sizeof來返回類型以及靜態分配的對象、結構或數組所佔的空間,返回值跟對象、結構、數組所存儲的內容沒有關係。spa

(4)具體而言,當參數分別以下時,sizeof返回的值表示的含義以下:指針

    數組——編譯時分配的數組空間大小;code

    指針——存儲該指針所用的空間大小(存儲該指針的地址的長度,是長整型,應該爲4);對象

    類型——該類型所佔的空間大小;three

    對象——對象的實際佔用空間大小;內存

    函數——函數的返回類型所佔的空間大小。函數的返回類型不能是void。字符串

二、strlen()

 (1)strlen()是函數,要在運行時才能計算。參數必須是字符型指針(char*)。當數組名做爲參數傳入時,實際上數組就退化成指針了。編譯器

(2)功能:返回字符串的長度。該字符串多是本身定義的,也多是內存中隨機的,該函數實際完成的功能是從表明該字符串的第一個地址開始遍歷,直到遇到結束符NULL。返回的長度大小不包括NULL。

三、區別

(1)實例1

char arr[10] = "What?";
int len_one = strlen(arr);
int len_two = sizeof(arr); 
cout << len_one << " and " << len_two << endl; 
#輸出結果爲:5 and 10

點評:sizeof返回定義arr數組時,編譯器已經爲其分配的數組空間大小,不關內心面存了多少數據。strlen只關心存儲的數據內容,不關心空間的大小和類型。

(2)實例2

char * parr = new char[10];
int len_one = strlen(parr);
int len_two = sizeof(parr);
int len_three = sizeof(*parr);
cout << len_one << " and " << len_two << " and " << len_three << endl;
#輸出結果:23 and 4 and 1

點評:第一個輸出結果23實際上每次運行可能不同,這取決於parr裏面存了什麼(從parr[0]開始知道遇到第一個NULL結束);第二個結果實際上本意是想計算parr所指向的動態內存空間的大小,可是事與願違,sizeof認爲parr是個字符指針,所以返回的是該指針所佔的空間(指針的存儲用的是長整型,因此爲4);第三個結果,因爲*parr所表明的是parr所指的地址空間存放的字符,因此長度爲1。

四、易錯點

請問在64位平臺機器下sizeof(string_a),sizeof(string_b)大小分別是() 

1.char *string_a=(char *)malloc(100*sizeof(char));
2.char string_b[100];

    A、8 100
    B、100 8
    C、100 100
    D、8 8

分析:

string_a是一個char型的指針,在64位系統中sizeof(char*)=8,這裏不要誤覺得

malloc(100*sizeof(char))

則string_a爲100,這裏分配的內存大小是100,可是指向這個區域的指針變量爲char類型的。

string_b是一個char型的數組,在64位系統中sizeof(char)=1,共100值所以爲100

相關文章
相關標籤/搜索