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