博客
关于我
strlen 函数
阅读量:729 次
发布时间:2019-03-21

本文共 1208 字,大约阅读时间需要 4 分钟。

以下是经过优化后的技术文章:

说的不是对吗?strlen函数到底是怎么回事呢?

在编写代码的时候,(strlen函数可能引起你们很多困惑。它到底是怎么算字符串长度的呢?我们今天就来聊聊这个问题。

strlen是怎么算字符串长度的?

strlen函数的作用非常简单——它会返回你指定字符串的总字符数。但是,和你想象的不一样,strlen的计算结果并不是从字符串始招到结束符的位置。如果你有一个字符串"hello",strlen返回的就是5,因为字符串中共有5个字符。而这个数值和实际存储的字符串长度是一样的。

什么是C语言的字符串?

在C语言中,一个字符串是用char类型的数组来表示的。每个字符串最终都会以特殊的'\0'字符结尾。这个字符看起来像是没有什么特别的作用,但它实际上决定了字符串的实际有效长度。编译器在编译字符串时会自动加上这个'\0',因此,一个声明为char str[50]的字符串,其最大存储空间是50个字符。但实际上,它可能只有其中一部分被赋予非'\0'的值。比如:

char str[50] = "I love zhangshangbiancheng!";

这条语句创建了一个可以存储50个字节的数组,但实际使用的只是长度为21的二进制串(不计算'\0')。所以,在这种情况下:

  • sizeof(str) 返回50,因为它表示的是数组的大小。
  • strlen(str) 返回21,因为这是有效字符的数量,不包含终止符。

为什么要分开使用strlen和 sizeof呢?

这可能让很多人困惑——为什么编程世界里需要两个不同的函数来获取字符串长度?这是因为它们做了完全不同的事情:

  • strlen 用于确定字符串中有多少字符实际显示或用于操作。
  • sizeof 返回的是数组在内存中占用的空间,包括所有预留的位置,包括终止符。

当心不要犯的常见错误

在编程过程中,许多开发者容易犯以下几个错误:

  • 混淆了字符串长度和数组大小

    就像我们看到的例子一样,数组的大小是50,但字符串实际包含的字符数只有21。这是一个常见的错误,特别是在处理静态数组时。

  • 忘记终止符的重要性

    如果不为字符串添加终止符,strlen可能会返回错误的值。因为在没有'\0'的情况下,函数无法正确确定字符串的终点。

  • 错误理解静态和动态字符串

    动态字符串(malloc.Align)通常不需要手动添加终止符,因为它们会在分配时自动处理。不过在大多数情况下,静态字符串需要手动添加终止符。

  • 总结

    strlen 函数的作用是为你节省时间,自动去计算字符串实际包含的字符数量。这对于任何编程任务来说都是非常有用的工具。然而你也需要了解其背后的工作原理,并了解数组大小和终止符的关系。通过理解这些概念,你能更好地掌握C语言编程。最初这些概念看起来可能有点抽象,但一旦你明白了它们的逻辑,就容易了。希望你在从 tomorrow的学习中取得更好的进步。

    转载地址:http://dupgz.baihongyu.com/

    你可能感兴趣的文章
    nginx:/usr/src/fastdfs-nginx-module/src/common.c:21:25:致命错误:fdfs_define.h:没有那个文件或目录 #include
    查看>>
    Nginx:NginxConfig可视化配置工具安装
    查看>>
    Nginx:现代Web服务器的瑞士军刀 | 文章末尾送典藏书籍
    查看>>
    ngModelController
    查看>>
    ngnix配置文件
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    ngrok内网穿透可以实现资源共享吗?快解析更加简洁
    查看>>
    ngrok内网穿透可以实现资源共享吗?快解析更加简洁
    查看>>
    NHibernate动态添加表
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    Nhibernate的第一个实例
    查看>>
    NHibernate示例
    查看>>
    nid修改oracle11gR2数据库名
    查看>>
    NIFI1.21.0/NIFI1.22.0/NIFI1.24.0/NIFI1.26.0_2024-06-11最新版本安装_采用HTTP方式_搭建集群_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_插入时如果目标表中已存在该数据则自动改为更新数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0058
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>