為什麼會寫sizeof
與strlen
的區別與聯絡,主要遇到的問題:
char a = 「abcdef」;
char b = ;
printf(「%d\n」,strlen(a));//輸出的是6
printf(「%d\n」,strlen(b));//輸出乙個未知數10;
a陣列表示的是字串,所以系統自動的在最後新增
\0;
而b陣列是乙個不帶串結束符的字元陣列;
所以在strlen
的時候b
陣列產生不可預知的錯誤,主要是沒有讀到
\0,所以沒有結束的標誌;
printf(「%d\n」,sizeof(a));//輸出的結果是7;
printf(「%d\n」,sizeof(b));//輸出的結果是6;
a陣列的時候最後補充了
\0,也佔了乙個位元組;
b陣列只是乙個字元陣列;
總結:sizeof與
strlen
的區別與注意事項
1.sizeof操作符的結果型別是
size_t
,它在標頭檔案中
typedef
為unsigned int
型別。
該型別保證能容納實現所建立的最大物件的位元組大小。
2.sizeof是算符,
strlen
是函式。
3.sizeof可以用型別做引數,
strlen
只能用char*
做引數,且必須是以
''\0''
結尾的。
sizeof還可以用函式做引數,比如:
short f();
printf("%d\n", sizeof(f()));
輸出的結果是sizeof(short),即2
。 4.陣列做
sizeof
的引數不退化,傳遞給
strlen
就退化為指標了。
5.大部分編譯程式 在編譯的時候就把
sizeof
計算過了 是型別或是變數的長度這就是
sizeof(x)
可以用來定義陣列維數的原因
char str[20]="0123456789";
int a=strlen(str); //a=10;
int b=sizeof(str); //而
b=20;
6.strlen的結果要在執行的時候才能計算出來,時用來計算字串的長度,不是型別佔記憶體的大小。
7.sizeof後如果是型別必須加括弧,如果是變數名可以不加括弧。這是因為
sizeof
是個操作符不是個函式。
8.當適用了於乙個結構型別時或變數,
sizeof
返回實際的大小,
當適用一靜態地空間陣列, sizeof
歸還全部陣列的尺寸。
sizeof 操作符不能返回動態地被分派了的陣列或外部的陣列的尺寸
9.陣列作為引數傳給函式時傳的是指標而不是陣列,傳遞的是陣列的首位址,
如: fun(char [8])
fun(char )
都等價於 fun(char *)
上面是對靜態陣列處理的結果,如果是對指標,結果就不一樣了。
char* ss = "0123456789";
sizeof(ss) 結果
4===》
ss是指向字串常量的字元指標,
sizeof
獲得的是乙個指標的之所佔的空間
,應該是長整型的,所以是4
sizeof(*ss) 結果
1===》
*ss是第乙個字元 其實就是獲得了字串的第一位
'0'所佔的記憶體空間,是
char
型別的,佔了1 位
strlen(ss)= 10 >>>> 如果要獲得這個字串的長度,則一定要使用
strlen;
對於sizeof
只是一種運算子,僅僅計算要算的的型別或者物件,或者是函式的所佔的記憶體的空間的大小;對於
strlen
僅僅裡面乙個方便計算字串的函式,並以
\0結束。
sizeof 與 strlen 的區別
一 示例 eg1 下列 char buffer 256 char pbuffer buffer cout sizeof buffer cout sizeof pbuffer 其執行結果為 eg2 簡單說明 sizeof gives the amount of storage,in bytes,ass...
strlen與sizeof的區別
1.sizeof操作符的結果型別是size t,它在標頭檔案中typedef為unsigned int型別。該型別保證能容納實現所建立的最大物件的位元組大小。2.sizeof是算符,strlen是函式。3.sizeof可以用型別做引數,strlen只能用char 做引數,且必須是以 0 結尾的。4....
sizeof與strlen的區別
sizeof 表示式 是c c 關鍵字 不是函式 功能 返回 表示式 結果所佔機器 位元組 的大小。strlen 字串 是c c 標準庫的函式 不是關鍵字 在標頭檔案 string.h 中宣告。功能 計算 字串 中的 0 之前的字元個數。特別注意 strlen總是假定傳給它的引數是以null結束符 ...