• 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返回这一段内存空间中总共有多少个字符,无论如何这个数值不可能是正确的。

     

  • 相关阅读:
    为知笔记使用备注
    困惑激发的正能量
    再多坚持一会,相信自己就好!
    看博文《前路漫漫,何为终点?》的一点小感想
    前端的杂谈
    JS 客户端检测
    DOM
    JavaScript & XML
    我所认识的XPath
    Javascript 面向对象编程
  • 原文地址:https://www.cnblogs.com/heyonggang/p/2813798.html
Copyright © 2020-2023  润新知