C語言中sizeof與strlen區別

sizeof 初始的分配的空間大小,期中數組

sizeof(unsigned char) = 1;
sizeof(signed char) = 1;     
  sizeof(int) = 4;
sizeof(unsigned int) = 4;
sizeof(short int) = 2;
sizeof(unsigned short) = 2;
sizeof(long int) = 4;
sizeof(unsigned long) = 4;
sizeof(float) = 4;
sizeof(double) = 8;
sizeof(long double) = 12;
sizeof(char *)=4;
例如: char a[5];
int b[5];
sizeof(a) = 5;
sizeof(b) = 20;
strlen是該數組的長度:如

(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,因此返回的值是一個不肯定的值。

相關文章
相關標籤/搜索