【幾個(gè)例子】
例子1:
char* ss = "0123456789";
sizeof(ss) //4, ss是指向字符串常量的字符指針
strlen(ss) //10, 只能用它獲得這個(gè)字符串的長度
char ss[] = "0123456789";
sizeof(ss) //11, ss是數(shù)組,計(jì)算到‘\0’位置,因此是10+1
strlen(ss) //10, strlen是個(gè)函數(shù)內(nèi)部實(shí)現(xiàn)是用一個(gè)循環(huán)計(jì)算到\0為止之前
char ss[100] = "0123456789";
sizeof(ss) //100, ss表示在內(nèi)存中的大小100×1
strlen(ss) //10, strlen是個(gè)函數(shù)內(nèi)部實(shí)現(xiàn)是用一個(gè)循環(huán)計(jì)算到\0為止之前
int ss[100] = "0123456789";
sizeof(ss) //400, ss表示再內(nèi)存中的大小100×4
strlen(ss) //錯(cuò)誤, strlen的參數(shù)只能是char* 且必須是以‘\0‘結(jié)尾
例子2:
class X
{
int i;
int j;
char k;
};
X x;
cout<<sizeof(X)<<endl; 結(jié)果 12 內(nèi)存補(bǔ)齊
cout<<sizeof(x)<<endl; 結(jié)果 12 同上
例子3:
char szPath[MAX_PATH]
如果在函數(shù)內(nèi)這樣定義,那么sizeof(szPath)將會(huì)是MAX_PATH,但是將szPath作為虛參聲明時(shí)(void fun(char szPath[MAX_PATH])),sizeof(szPath)卻會(huì)是4(指針大小),即如果操作數(shù)是函數(shù)中的數(shù)組形參或函數(shù)類型的形參,sizeof給出其指針的大小。
【sizeof與strlen區(qū)別總結(jié)】
1.sizeof是運(yùn)算符,strlen是函數(shù)。
2. strlen是有效字符串的長度,不包含‘\0’,與初始化有關(guān)系,而sizeof與初不初始化沒有關(guān)系
3.sizeof可以用類型做參數(shù),用來計(jì)算類型占內(nèi)存大小,strlen只能用char*做參數(shù),且必須是以'\0'結(jié)尾的,用來計(jì)算字符串的長度;
4.數(shù)組做sizeof的參數(shù)不退化,傳遞給strlen就退化為指針了。
5. sizeof在編譯時(shí)計(jì)算,而strlen的結(jié)果在運(yùn)行時(shí)才能計(jì)算出來,
【課堂測試】
1. 如下程序的輸出是什么?(在intel x86(32-bit) platform.)
#include <stdio.h>
#include<stdlib.h>
#include<string.h>
int main( )
{
char str[10];
char *p;
memset(str,0x00,sizeof(str));
p = (char *)malloc(100);
printf("%d\n",sizeof(p));
printf("%d\n",sizeof('p'));
printf("%d\n",strlen(str));
exit(0);
}
答:4/1/0, 如果不加memset(),第三行就會(huì)打出15(隨機(jī)數(shù)),請問這是為什么?memset函數(shù)是初始化分配的內(nèi)存空間,使用0、0x00都是0即’\0',不同系統(tǒng)當(dāng)分配一塊內(nèi)存時(shí),這塊內(nèi)存中的內(nèi)容是未知的,系統(tǒng)只是根據(jù)申請者的要求為其化一塊內(nèi)存并不管他原先的內(nèi)容是什么(有的系統(tǒng)清零),所以你的是隨即數(shù)15。
2.你能夠正確的說出它們的sizeof和strlen的大小嗎?
#include <stdio.h>
#include<stdlib.h>
#include<string.h>
int main( )
{
char *str1="absde";
char str2[]="absde";
char str3[8]={'a',};
char str4[8]={'a','b','s','e','f','g','h','j'};
printf("sizeof(str1)=%d\n",sizeof(str1));
printf("sizeof(str2)=%d\n",sizeof(str2));
printf("sizeof(str3)=%d\n",sizeof(str3));
printf("sizeof(str4)=%d\n",sizeof(str4));
printf("strlen(str1)=%d\n",strlen(str1));
printf("strlen(str2)=%d\n",strlen(str2));
printf("strlen(str3)=%d\n",strlen(str3));
printf("strlen(str4)=%d\n",strlen(str4));
exit(0);
}
答:sizeof是計(jì)算括號中變量的類型所占的儲存空間(不考慮內(nèi)容);strlen是計(jì)算變量值為起點(diǎn)的內(nèi)存地址到第一個(gè)'\0'的距離,以字節(jié)為單位,字符串尾部為'\0',0=='\0'(不包括’\0’)。正確答案是:4、6、8、8;5、5、1、9;
3. 你能夠正確的說出它們的sizeof和strlen的大小嗎?
char *str1="absde";
char str2[]="absde";
char str3[8]={'a',};
char str4[8]={'a','b','s','e','f','g','h','j'};
答案:
sizeof(str1)=4;
sizeof(*str1)=1;
strlen(str1)=5;
sizeof(str2)=6;
strlen(str2)=5;
sizeof(str3)=8;
strlen(str3)=1;
sizeof(str4)=8;
strlen(str4)=13;
strlen(*str1) 出錯(cuò)
strlen(str4)有可能為不小于8的其他數(shù)字,取決于內(nèi)存中的數(shù)據(jù),因?yàn)閟trlen是計(jì)算變量值為起點(diǎn)的內(nèi)存地址到第一個(gè)'\0'的距離,但'\0'出現(xiàn)位置我們是未知的。