博客
关于我
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/

    你可能感兴趣的文章
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    【Flink】Flink 1.9 版本 web UI 突然没有日志
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>