1樓:雲澹楓卿
求長度通常是strlen和sizeof
下面是他倆的區別幫助你知道
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 *)
在c++裡引數傳遞陣列永遠都是傳遞指向陣列首元素的指標,編譯器不知道陣列的大小
如果想在函式內知道陣列的大小, 需要這樣做:
進入函式後用memcpy拷貝出來,長度由另一個形參傳進去
fun(unsiged char *p1, int len)
我們能常在用到 sizeof 和 strlen 的時候,通常是計算字串陣列的長度
看了上面的詳細解釋,發現兩者的使用還是有區別的,從這個例子可以看得很清楚:
char str[20]="0123456789";
int a=strlen(str); //a=10; >>>> strlen 計算字串的長度,以結束符 0x00 為字串結束。
int b=sizeof(str); //而b=20; >>>> sizeof 計算的則是分配的陣列 str[20] 所佔的記憶體空間的大小,不受裡面儲存的內容改變。
上面是對靜態陣列處理的結果,如果是對指標,結果就不一樣了
char* ss = "0123456789";
sizeof(ss) 結果 4 ===》ss是指向字串常量的字元指標,sizeof 獲得的是一個指標的之所佔的空間,應該是
長整型的,所以是4
sizeof(*ss) 結果 1 ===》*ss是第一個字元 其實就是獲得了字串的第一位'0' 所佔的記憶體空間,是char類
型的,佔了 1 位
strlen(ss)= 10 >>>> 如果要獲得這個字串的長度,則一定要使用 strlen
2樓:匿名使用者
使用sizeof操作符可以計算任何型別陣列的長度。
使用方法:
sizeof(a)/sizeof(a[0]); //其中a是陣列名。
原理就是,用整個陣列的位元組數除以一個元素的位元組數,結果就是陣列的長度。
sizeof判斷資料型別長度符的關鍵字
用法sizeof(型別說明符,陣列名或表示式)或sizeof 變數名定義sizeof是c/c++中的一個操作符(operator),簡單的說其作用就是返回一個物件或者型別所佔的記憶體位元組數。
3樓:匿名使用者
常用的方法是另設一個整型變數用來記錄陣列中的有效元素的個數。
4樓:匿名使用者
用sizeof運算子吧,printf("%d",&sizeof(a))
5樓:篤俠
sizeof(a)/sizeof(struct x)
c語言程式設計中,輸入一個字串陣列,如何得出該陣列的長度?
6樓:匿名使用者
使用c語言函式strlen()
函式原型:extern unsigned int strlen(char *s);,在visual c++ 6.0中,原型為size_t strlen( const char *string );,其中size_t實際上是unsigned int,在vc6.
0中可以看到這樣的**:typedef unsigned int size_t;。
標頭檔案:string.h
功能:計算字串s的(unsigned int型)長度說明:返回s的長度,不包括結束符null。
程式舉例:
#include
#include
int main(void)
在C語言中如何使用bool型別
布林型 bool 變數的值只有 真 true 和假 false 布林型變數可用於邏輯表示式,也就是 或 與 非 之類的邏輯運算和大於小於之類的關係運算,邏輯表示式運算結果為真或為假。bool可用於定義函式型別為布林型,函式裡可以有 return true return false 之類的語句。布林型...
C語言中強制型別轉換會改變原來變數的型別麼?比如a float b,那麼b的也會變成浮點型麼
題主的關注點應該在強制型別轉換後原地址的型別不會變上,但如果a也是整型,這樣把一個浮點數賦值給一個整型,也會進行強制型別轉換,即我認為a還是整型。thx 不會,你宣告b是什麼型別,強制型別轉換賦值後,b還是原來的型別的 a float b,是將b的型別強制裝換為浮點型後給a,但b的型別沒有發生改變....
關於C語言中各型別資料間的混合運算
兩種不同型別的數運算的時候,根據包容性,將低階範圍的轉換成高範圍的,將小的轉換為大的。這樣才能保證結果更正確。比如將單精度轉換成雙精度,將short轉換為long等。所以,結果是雙精度的。如果結果儲存到單精度的變數,將會有一個warning的編譯警告。這個問題其實是基礎問題。兩個單精度運算的話,系統...