因?yàn)閟izeof數(shù)組取的是屬于頭部指針的字節(jié)數(shù),指針都是4個(gè)字節(jié)長(zhǎng)度,strlen是整個(gè)字符串的長(zhǎng)度
sizeof和strlen是兩個(gè)不同的C語言函數(shù),主要有以下區(qū)別:
1. 作用對(duì)象不同:sizeof是用于計(jì)算數(shù)據(jù)類型的大小,而strlen是用于計(jì)算字符串的長(zhǎng)度。
2. 參數(shù)類型不同:sizeof可以計(jì)算任意數(shù)據(jù)類型的大小,包括基本數(shù)據(jù)類型、結(jié)構(gòu)體、數(shù)組、指針等等,而strlen只能計(jì)算以空字符'\0'結(jié)尾的字符串的長(zhǎng)度,即字符數(shù)組或指向字符數(shù)組的指針。
3. 返回值類型不同:sizeof返回的是一個(gè)無符號(hào)整數(shù),表示數(shù)據(jù)類型或變量占用的字節(jié)數(shù),而strlen返回的是一個(gè)整數(shù),表示字符串的長(zhǎng)度,不包含空字符'\0'。
4. 計(jì)算方式不同:sizeof在編譯時(shí)就能夠計(jì)算出數(shù)據(jù)類型或變量的大小,而不需要在運(yùn)行時(shí)計(jì)算;而strlen需要遍歷字符串的每個(gè)字符,直到遇到空字符'\0'才能確定字符串的長(zhǎng)度。
總之,sizeof和strlen是兩個(gè)不同的函數(shù),應(yīng)該根據(jù)具體的需求選擇使用。如果需要計(jì)算字符串的長(zhǎng)度,應(yīng)該使用strlen函數(shù);如果需要計(jì)算數(shù)據(jù)類型或變量的大小,應(yīng)該使用sizeof函數(shù)。
1、打開VS2017創(chuàng)建一個(gè)C++控制臺(tái)應(yīng)用程序。
2、首先,功能不同。sizeof()是操作符,計(jì)算任意類型參數(shù)所占內(nèi)存大小。
3、strlen()是函數(shù),計(jì)算以“\0”結(jié)束的字符串長(zhǎng)度,計(jì)算長(zhǎng)度不包括“\0”。
4、其次,參數(shù)不同。當(dāng)將字符數(shù)組作為sizeof()的參數(shù)時(shí),計(jì)算字符數(shù)組占用內(nèi)存大小。
5、當(dāng)將字符數(shù)組作為strlen()的參數(shù)時(shí),字符數(shù)組轉(zhuǎn)化為char*。
1.sizeof操作符的結(jié)果類型是size_t,它在頭文件中typedef為unsigned int類型。該類型保證能容納實(shí)現(xiàn)所建立的最大對(duì)象的字節(jié)大小。
2.sizeof是算符,strlen是函數(shù)。
3.sizeof可以用類型做參數(shù),strlen只能用char*做參數(shù),且必須是以''\0''結(jié)尾的。sizeof還可以用函數(shù)做參數(shù),比如: short f();printf("%d\n", sizeof(f()));輸出的結(jié)果是sizeof(short),即2。
4.數(shù)組做sizeof的參數(shù)不退化,傳遞給strlen就退化為指針了。
5.大部分編譯程序 在編譯的時(shí)候就把sizeof計(jì)算過了 是類型或是變量的長(zhǎng)度這就是sizeof(x)可以用來定義數(shù)組維數(shù)的原因 char str[20]="0123456789";int a=strlen(str); //a=10;int b=sizeof(str); //而b=20;
6.strlen的結(jié)果要在運(yùn)行的時(shí)候才能計(jì)算出來,時(shí)用來計(jì)算字符串的長(zhǎng)度,不是類型占內(nèi)存的大小。
7.sizeof后如果是類型必須加括弧,如果是變量名可以不加括弧。這是因?yàn)閟izeof是個(gè)操作符不是個(gè)函數(shù)。
8.當(dāng)適用了于一個(gè)結(jié)構(gòu)類型時(shí)或變量, sizeof 返回實(shí)際的大小,當(dāng)適用一靜態(tài)地空間數(shù)組, sizeof 歸還全部數(shù)組的尺寸。sizeof 操作符不能返回動(dòng)態(tài)地被分派了的數(shù)組或外部的數(shù)組的尺寸
9.數(shù)組作為參數(shù)傳給函數(shù)時(shí)傳的是指針而不是數(shù)組,傳遞的是數(shù)組的首地址,如: fun(char [8])fun(char [])都等價(jià)于 fun(char *) 在C++里參數(shù)傳遞數(shù)組永遠(yuǎn)都是傳遞指向數(shù)組首元素的指針,編譯器不知道數(shù)組的大小如果想在函數(shù)內(nèi)知道數(shù)組的大小, 需要這樣做:進(jìn)入函數(shù)后用memcpy拷貝出來,長(zhǎng)度由另一個(gè)形參傳進(jìn)去 fun(unsiged char *p1, int len){ unsigned char* buf = new unsigned char[len+1] memcpy(buf, p1, len);}
我們能常在用到 sizeof 和 strlen 的時(shí)候,通常是計(jì)算字符串?dāng)?shù)組的長(zhǎng)度看了上面的詳細(xì)解釋,發(fā)現(xiàn)兩者的使用還是有區(qū)別的,從這個(gè)例子可以看得很清楚:
char str[20]="0123456789";int a=strlen(str); //a=10; >>>> strlen 計(jì)算字符串的長(zhǎng)度,以結(jié)束符 0x00 為字符串結(jié)束。int b=sizeof(str); //而b=20; >>>> sizeof 計(jì)算的則是分配的數(shù)組 str[20] 所占的內(nèi)存空間的大小,不受里面存儲(chǔ)的內(nèi)容改變。
上面是對(duì)靜態(tài)數(shù)組處理的結(jié)果,如果是對(duì)指針,結(jié)果就不一樣了
char* ss = "0123456789";sizeof(ss) 結(jié)果 4 ===》ss是指向字符串常量的字符指針,sizeof 獲得的是一個(gè)指針的之所占的空間,應(yīng)該是
長(zhǎng)整型的,所以是4sizeof(*ss) 結(jié)果 1 ===》*ss是第一個(gè)字符 其實(shí)就是獲得了字符串的第一位'0' 所占的內(nèi)存空間,是char類
型的,占了 1 位
strlen(ss)= 10 >>>> 如果要獲得這個(gè)字符串的長(zhǎng)度,則一定要使用 strlen
strlen() 計(jì)算字符串長(zhǎng)度,計(jì)算到字符串結(jié)束符 '\0' 為止。如果沒有遇到 字符串結(jié)束符 '\0', 計(jì)算結(jié)果將不正確。上面語句中,你還沒有給 a 初始化,也未賦值,沒內(nèi)容。如果要算 數(shù)組占內(nèi)存大小 要用 sizeof() 運(yùn)算符,而不是 strlen.
可以,strlen函數(shù)是用來計(jì)算字符長(zhǎng)度,以\0結(jié)尾,string類型正好是字符串行的
sizeof可以用來求數(shù)組的長(zhǎng)度,例如:intarr[]={1,3,5,6,7,8,8,2};printf("%d\n",sizeof(arr)/sizeof(int)); //sizeof(arr)得到這個(gè)數(shù)組所占的內(nèi)存空間大小sizeof(int)是每個(gè)元素的大小,sizeof(arr)的結(jié)果等于32,因?yàn)槊總€(gè)int元素占4個(gè)字節(jié),這個(gè)數(shù)組有8個(gè)元素。
sizeof(char) = 1 sizeof(short) = 2 sizeof(int) = 2(16位機(jī)),4(32位機(jī)),8(64位機(jī)) sizeof(long) = 4(不知道64位機(jī)是多少) 這些其實(shí)是每種變量類型所占用的內(nèi)存的字節(jié)數(shù)。 malloc()中傳入的參數(shù)是內(nèi)存大小,單位為字節(jié)。 如果你要定義一個(gè) short 的,元素個(gè)數(shù)為7的數(shù)組,當(dāng)然就需要 7*2個(gè)字節(jié)的內(nèi)存大小。 如果ElemType是結(jié)構(gòu),也是同理。
通過sizeof可以計(jì)算出類型的長(zhǎng)度,同樣也可以計(jì)算出數(shù)組的長(zhǎng)度,但是這具有一定的局限性。 以下是一段示例代碼: session
1: 計(jì)算出數(shù)組的長(zhǎng)度 session
2: 通過函數(shù)計(jì)算出數(shù)組的長(zhǎng)度 session
3: 通過函數(shù)計(jì)算出數(shù)組的長(zhǎng)度
a=(int**)malloc(sizeof(int*)*r) 首先,這句話的意思就是使用malloc申請(qǐng)sizeof(int*)*r這么大的內(nèi)存空間。
其次,因?yàn)閙allo的返回值是void*類型,所以要進(jìn)行一個(gè)類型轉(zhuǎn)換,你可以轉(zhuǎn)換成任何的類型。
最后,因?yàn)槟阋敵鲆粋€(gè)3*5的矩陣,所以如果直接定義的話,應(yīng)該定義為inta[3][5],而這個(gè)a就是int**類型,所以你使用malloc分配內(nèi)存值,要將malloc的內(nèi)存類型格式化為int**類型。 int**p; inta[3][5]; p=a;//可以這樣賦值的。 輸出一個(gè)3*5數(shù)列的例子 #include?<stdio.h> #include?<stdlib.h> int?main() { ????int**?a?=?(int**
)malloc(sizeof(int*)*3); int?i=0,?j=0; for?(i=0;?i<3;?i++) { a[i]?=?(int*
)malloc(sizeof(int)*5); for?(j=0;?j<5;?j++) { *(*(a+i)+j)=j; } } for?(i=0;?i<3;?i++) { for?(j=0;?j<5;?j++) { printf("%d\t",?*(*(a+i)+j)); } printf("\n"); } delete[]?a; ????return?0; }