sizeof 初始的分配的空間大小,期中數組
(1)char * 指針
strlen(指針名)
若是參數是指針則計算該指針指向字符序列的長度。(以’\0’ 做爲判斷標誌)例如:
定義char *p=「hello world」;strlen(p)=11,而 sizeof (p)=4。能夠看到 strlen
計算的是指針指向的字符串的長度而sizeof 計算的是指針自己所佔用的內存空
間的大小。
(2)數組
strlen(數組名)
若是參數是數組的話,實際傳遞的是一個指針,strlen 會按照上面處理指針的模
式處理該數組。
咱們能夠看下面的例子:
char a[]=」hh」;
strlen(a);
很顯然strlen 的結果是2。可是若是數組是這樣賦值的呢?
char a[]={‘h’,’h’};
strlen(a);
那麼如今strlen(a )的結果又是多少呢?這個數就不必定了,緣由是 strlen 會去
計算a 地址開始的字符串的長度,因爲前一種賦值方式會將hh以字 符串的形式
賦值給數組會將字符串結束符’\0’ 一同賦值,這時strlen 就會檢查到結束符中止
計算,而第二種復值方式是以單個字符的形式賦值沒有結束 符’\0’, 這時咱們用
sizeof 獲得的結果是正常的,而用 strlen 因爲找不到結束符,會繼續的計算直到
找到結束符爲止。因此這個數是不肯定.spa
實例2:指針
char a[]="hello";內存
char b[]={'h','e','l','l','o'};字符串
strlen(a),strlen(b)的值分別是多少?io
前面分析過,strlen是求字符串的長度,字符串有個默認的結束符/0,這個結束符是在定義字符串的時候系統自動加上去的,就像定義數組a同樣。數組a定義了一個字符串,數組b定義了一個字符數組。所以,strlen(a)=5,而strlen(b)的長度就不肯定的,由於strlen找不到結束符。class
-------------------------test
One example變量
#define PATH_TMP "12345"
static void test_sizeof_strlen() {
char *msg = "12345";
printf("sizeof(msg)---%d\n" , sizeof(msg));
printf("strlen(msg)---%d\n" , strlen(msg));
char array[] = "12345";
printf("sizeof(array)---%d\n" , sizeof(array));
printf("strlen(array)---%d\n" , strlen(array));
printf("sizeof(PATH_TMP)---%d\n" , sizeof(PATH_TMP));
printf("strlen(PATH_TMP)---%d\n" , strlen(PATH_TMP));
}
The output result:
sizeof(msg)---4
strlen(msg)---5
sizeof(array)---6
strlen(array)---5
sizeof(PATH_TMP)---6
strlen(PATH_TMP)---5float
char *c="abcdef";
char d[]="abcdef";
char e[]={'a','b','c','d','e','f'};
printf("%d%d/n",sizeof(c),strlen(c));
printf("%d%d/n",sizeof(d),strlen(d));
printf("%d%d/n",sizeof(e),strlen(e));
輸出的結果是:
4 6
7 6
6 14
分析一下:
第一行定義c爲一個字符指針變量,指向常量字符串,c裏面存放的是字符串的首地址。
第二行定義d爲一個字符數組,以字符串的形式給這個字符數組賦值。
第三行定義的也是個字符數組,以單個元素的形式賦值。
當以字符串賦值時,"abcdef",結尾自動加一個"/0".
strlen(c)遇到/0就會結束,求的是字符串的長度,爲6.
sizeof(c)求的是類型空間大小,在前面說過,指針型所點的空間大小是4個字節,系統地址總線長度爲32位時。
strlen(d)也是同樣,字符串賦值,自動添加/0,求字符串的長度固然是6.
sizeof(d)是求這個數組所佔空間的大小,即數組所佔內存空間的字節數,應該爲7.
sizeof(e), 數組e以單個元素賦值,沒有/0結束符,因此所佔空間的大小爲6個字節。
strlen(e),去找/0結尾的字符串的長度,因爲找不到/0,因此返回的值是一個不肯定的值。