(1)sizeof()是運算符,在頭文件中typedef爲unsigned int,其值在編譯時即計算好了,參數能夠是數組、指針、類型、對象、函數等。數組
(2)功能:得到保證能容納實現所創建的最大對象的字節大小。函數
(3)因爲在編譯時計算,所以sizeof不能用來返回動態分配的內存空間的大小。實際上,用sizeof來返回類型以及靜態分配的對象、結構或數組所佔的空間,返回值跟對象、結構、數組所存儲的內容沒有關係。spa
(4)具體而言,當參數分別以下時,sizeof返回的值表示的含義以下:指針
數組——編譯時分配的數組空間大小;code
指針——存儲該指針所用的空間大小(存儲該指針的地址的長度,是長整型,應該爲4);對象
類型——該類型所佔的空間大小;three
對象——對象的實際佔用空間大小;內存
函數——函數的返回類型所佔的空間大小。函數的返回類型不能是void。字符串
(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