strlen()函数和sizeof算符

区别:

一、定义不同

sizeof是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组、指针、类型、对象、函数等。

2、它的功能是:获得保证能容纳实现所建立的最大对象的字节大小。具体而言,当参数分别如下时,sizeof返回的值表示的含义如下:数组——编译时分配的数组空间大小;指针——存储该指针所用的空间大小(存储该指针的地址的长度,是长整型,应该为4)。

常用

int a[] = {3,5,7,8,5,4,3,};

int m = sizeof(a)/sizeof(int);

m = 7;

关于sizeof()的学习,自己确实花了不少功夫,对于sizeof()的用法也有了一定的认识,今天遇到一位神题,我估计大家也会做错。。。切入正题吧:

点击(此处)折叠或打开

  1. #include <stdio.h>
  2. int main()
  3. {
  4.     if(sizeof(int) - sizeof(double) < 0)
  5.     {
  6.         printf("<\n");
  7.     }
  8.     else
  9.     {
  10.         printf(">=\n");
  11.     }
  12.     return 0;
  13. }

       求以上程序的输出结果,我们知道sizeof(int) = 4, sizeof(double) =  8, 则4 -8 = -4 ,则if(sizeof(int) - sizeof(double) < 0)的条件为真,所以,输出应该是打印出“<”,程序运行的结果如下:

点击(此处)折叠或打开

  1. >=

      发现和预期的结果相反,究其原因,原来sizeof()的返回值是一个无符号整型十进制数值,即:unsigend int 型,所以两个unsigend int型的数据进行运算后其结果只能是unsigend int型的,即大于等于0的一个整数值,所以,if()条件不满足,执行下一条语句。这个错误比较隐蔽,很容易出错,今天遇到了在此做一个记录,以便以后的复习。

二、语法不同

1、strlen是函数,要在运行时才能计算。参数必须是字符型指针。当数组名作为参数传入时,实际上数组就退化成指针了。

2、它的功能是:返回字符串的长度。该字符串可能是自己定义的,也可能是内存中随机的,该函数实际完成的功能是从代表该字符串的第一个地址开始遍历,直到遇到结束符NULL。返回的长度大小不包括NULL。

扩展资料

1、sizeof是算符,strlen是函数。 数组做sizeof的参数不退化,传递给strlen就退化为指针了。strlen所作的仅仅是一个计数器的工作,它从内存的某个位置(可以是字符串开头,e799bee5baa6e997aee7ad94e4b893e5b19e31333365666237中间某个位置,甚至是某个不确定的内存区域)开始扫描,直到碰到第一个字符串结束符'\0'为止,然后返回计数器值(长度不包含'\0')。

2、sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型。该类型保证能容纳实现所建立的最大对象的字节大小。

这里需要特别注意的是,函数 strlen 返回的是一个类型为 size_t 的值,从而有可能让程序导致意想不到的结果,如下面的示例代码所示:

  1. /*判断一*/
  2. if(strlen(x)>= strlen(y))
  3. {
  4. }
  5. /*判断二*/
  6. if(strlen(x)- strlen(y)>= 0)
  7. {
  8. }

从表面上看,上面的两个判断表达式完全相等,但实际情况并非如此。其中,判断表达式一没什么问题,程序也能够完全按照预想的那样工作;但判断表达式二的结果就不一样了,它将永远是真,这是为什么呢?

原因很简单,因为函数 strlen 的返回结果是 size_t 类型(即无符号整型),而 size_t 类型绝不可能是负的。因此,语句“if(strlen(x)-strlen(y)>=0)”将永远为真。

猜你喜欢

转载自www.cnblogs.com/FutureSience/p/12819726.html