sizeof與strlen區別

sizeof與strlen區別

今天遇到這麼個問題,下面是蒐集到得資料,分享給有需要的朋友,反正就是求字符串或者數組長度最好用strlen,求佔有內存用sizeof!!! 


 strlen(char*)函數求的是字符串的實際長度,它求得方法是從開始到遇到第一個'\0',如果你只定義沒有給它賦初值,這個結果是不定的,它會從aa首地址一直找下去,直到遇到'\0'停止。

  char aa[10];cout<<strlen(aa)<<endl; //結果是不定的
  char aa[10]={'\0'}; cout<<strlen(aa)<<endl; //結果爲0
  char aa[10]="jun"; cout<<strlen(aa)<<endl; //結果爲3
  而sizeof()函數返回的是變量聲明後所佔的內存數,不是實際長度。
  sizeof(aa) 返回10
  int a[10]; sizeof(a) 返回40
  1.sizeof操作符的結果類型是size_t,它在頭文件中typedef爲unsigned int類型。
  該類型保證能容納實現所建立的最大對象的字節大小。
  2.sizeof是算符,strlen是函數。
  3.sizeof可以用類型做參數,strlen只能用char*做參數,且必須是以''\0''結尾的。
  sizeof還可以用函數做參數,比如:
  short f();
  printf("%d\n", sizeof(f()));
  輸出的結果是sizeof(short),即2。
  4.數組做sizeof的參數不退化,傳遞給strlen就退化爲指針了。
  5.大部分編譯程序 在編譯的時候就把sizeof計算過了是類型或是變量的長度這就是sizeof(x)可以用來定義數組維數的原因
  char str[20]="0123456789";
  int a=strlen(str); //a=10;
  int b=sizeof(str); //而b=20; 爲str佔用的內存大小
  6.strlen的結果要在運行的時候才能計算出來,是用來計算字符串的長度,不是類型佔內存的大小。
  7.sizeof後如果是類型必須加括弧,如果是變量名可以不加括弧。這是因爲sizeof是個操作符不是個函數。
  8.當適用於一個結構類型時或變量, sizeof 返回實際的大小,當適用於靜態的空間數組, sizeof 歸還全部數組的尺寸。
  sizeof 操作符不能返回被動態分派的數組或外部數組的尺寸
  9.數組作爲參數傳給函數時傳的是指針而不是數組,傳遞的是數組的首地址,
  如:
  fun(char [8])
  fun(char [])
  都等價於 fun(char *)
  在C++裏參數傳遞數組永遠都是傳遞指向數組首元素的指針,編譯器不知道數組的大小
  如果想在函數內知道數組的大小, 需要這樣做:
  進入函數後用memcpy拷貝出來,長度由另一個形參傳進去
  fun(unsiged char *p1, int len)
  {
  unsigned char* buf = new unsigned char[len+1]
  memcpy(buf, p1, len);
  }
  我們經常使用 sizeof 和 strlen 的場合,通常是計算字符串數組的長度
  看了上面的詳細解釋,發現兩者的使用還是有區別的,從這個例子可以看得很清楚:
  char str[20]="0123456789";
  int a=strlen(str); //a=10; >>>> strlen 計算字符串的長度,以結束符 0x00 爲字符串結束。
  int b=sizeof(str); //而b=20; >>>> sizeof 計算的則是分配的數組 str[20] 所佔的內存空間的大小,不受裏面存儲的內容改變。
  上面是對靜態數組處理的結果,如果是對指針,結果就不一樣了
  char* ss = "0123456789";
  sizeof(ss) 結果 4 ===》ss是指向字符串常量的字符指針,sizeof 獲得的是一個指針的之所佔的空間,應該是
  長整型的,所以是4
  sizeof(*ss) 結果 1 ===》*ss是第一個字符 其實就是獲得了字符串的第一位'0' 所佔的內存空間,是char類
  型的,佔了 1 位
  strlen(ss)= 10 >>>> 如果要獲得這個字符串的長度,則一定要使用 strlen
  sizeof返回對象所佔用的字節大小. //正確
  strlen返回字符個數. //正確
  在使用sizeof時,有一個很特別的情況,就是數組名到指針蛻變,
  char Array[3] = {'0'};
  sizeof(Array) == 3;
  char *p = Array;
  strlen(p) == 1;//sizeof(p)結果爲4
  在傳遞一個數組名到一個函數中時,它會完全退化爲一個指針

  ----------------------------------------------------------




看完上面就應該差不多了!!!下面的可以不用看了,如果還不清楚接着看!





  看完以上你是否很清楚sizeof和strlen的區別了呢?還不明白的話,我們看下面幾個例子:
  第一個例子
  char* ss = "0123456789";
  sizeof(ss) 結果 4 ===》ss是指向字符串常量的字符指針
  sizeof(*ss) 結果 1 ===》*ss是第一個字符
  大部分編譯程序 在編譯的時候就把sizeof計算過了 是類型或是變量的長度
  這就是sizeof(x)可以用來定義數組維數的原因
  char str[20]="0123456789";
  int a=strlen(str); //a=10;
  int b=sizeof(str); //而b=20;
  大部分編譯程序 在編譯的時候就把sizeof計算過了 是類型或是變量的長度
  這就是sizeof(x)可以用來定義數組維數的原因
  char str[20]="0123456789";
  int a=strlen(str); //a=10;
  int b=sizeof(str); //而b=20;
  char ss[] = "0123456789";
  sizeof(ss) 結果 11 ===》ss是數組,計算到\0位置,因此是10+1
  sizeof(*ss) 結果 1 ===》*ss是第一個字符
  char ss[100] = "0123456789";
  sizeof(ss) 結果是100 ===》ss表示在內存中的大小 100×1
  strlen(ss) 結果是10 ===》strlen是個函數內部實現是用一個循環計算到\0爲止之前
  int ss[100] = "0123456789";
  sizeof(ss) 結果 400 ===》ss表示在內存中的大小 100×4
  strlen(ss) 錯誤 ===》strlen的參數只能是char* 且必須是以'\0'結尾的
  char q[]="abc";
  char p[]="a\n";
  sizeof(q),sizeof(p),strlen(q),strlen(p);
  結果是 4 3 3 2
  第三個例子
  char szPath[MAX_PATH]
  如果在函數內這樣定義,那麼sizeof(szPath)將會是MAX_PATH,但是將szPath作爲虛參聲明時(void fun(char szPath[MAX_PATH])),sizeof(szPath)卻會是4(指針大小)
  子
  char szPath[MAX_PATH]
  如果在函數內這樣定義,那麼sizeof(szPath)將會是MAX_PATH,但是將szPath作爲虛參聲明時(void fun(char szPath[MAX_PATH])),sizeof(szPath)卻會是4(指針大小)
  還有一位網友的說明也很好:
  其實理解 sizeof 只需要抓住一個要點:棧
  程序存儲分佈有三個區域:棧、靜態和動態。能夠從代碼直接操作的對象,包括任何類型的變量、指針,都是在棧上的;動態和靜態存儲區是靠棧上的所有指針間接操作的。 sizeof 操作符,計算的是對象在棧上的投影體積;記住這個就很多東西都很清楚了。
  char const * static_string = "Hello";
  sizeof(static_string) 是 sizeof 一個指針,所以在 32bit system 是 4
  char stack_string[] = "Hello";
  sizeof(stack_string) 是 sizeof 一個數組,所以是 6 * sizeof(char)
  char * string = new char[6];
  strncpy(string, "Hello", 6");
  sizeof(string) 是 sizeof 一個指針,所以還是 4。和第一個不同的是,這個指針指向了動態存儲區而不是靜態存儲區。
  不管指針指向的內容在什麼地方,sizeof 得到的都是指針的棧大小
  C++ 中對引用的處理比較特殊;sizeof 一個引用得到的結果是 sizeof 一個被引用的對象的大小;所以
  struct O
  {
  int a, b, c, d, e, f, g, h;
  };
  int main()
  {
  O & r = *new O;
  cout << sizeof(O) << endl; // 32
  cout << sizeof r << endl; // 也是 32
  system("PAUSE");
  }
  r 引用的是整個的 O 對象而不是指向 O 的指針,所以 sizeof r 的結果和 sizeof O 完全相同。
發佈了25 篇原創文章 · 獲贊 10 · 訪問量 32萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章