sizeof和strlen的区别

第一个例子: 

  char *ss="0123456789";
   sizeof(ss)=4, ss是指向字符串常量的字符指针
   sizeof(*ss)=1, *ss是第一个字符。
第二个例子:   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,它的内部是用一个循环计算字符串的长度,直到“\0”为止。
第四个例子:   int ss[100]="0123456789";
   sizeof(ss)=400,ss表示在内存中的大小,100*4
   strlen(ss)错误strlen的参数只能是char*,且必须是以“\0”结尾的。


对函数实用sizeof,在编译阶段会被函数返回值的类型取代。
如:int f1() { return 0;}
    cout<<sizeof(f1())<<endl;   // f1()返回值为int,因此被认为是int。    为4.

sizeof和strlen有以下区别:
  • sizeof是一个操作符,strlen是库函数。
  • sizeof的参数可以是数据的类型,也可以是变量,而strlen只能以结尾为‘\0’的字符串作参数。
  • 编译器在编译时就计算出了sizeof的结果,而strlen函数必须在运行时才能计算出来。并且sizeof计算的是数据类型占内存的大小,而strlen计算的是字符串实际的长度
  • 数组做sizeof的参数不退化,传递给strlen就退化为指针了。

 

《c++ primer》P115 

 

    char ca[] = {'C' , '+' , '+'};  //not null-terminated  
    cout<<strlen(ca)<<endl;  

 

在这个例题中,ca是一个没有null结束符的字符数组,则计算的结果不可预料。

标准库函数strlen总是假定其参数字符串以null字符结束,当调用标准库函数时,系统将会从实参ca指向的内存空间开始一直搜索结束符,直到恰好遇到null为止。

strlen返回这一段内存空间中总共有多少个字符,无论如何这个数值不可能是正确的。

 

原文地址:https://www.cnblogs.com/heyonggang/p/2813798.html