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

    你可能感兴趣的文章
    MySQL命令行操作的相关语法
    查看>>
    MySQL命令行登陆,远程登陆MySQL
    查看>>
    mysql命令:set sql_log_bin=on/off
    查看>>
    mySQL和Hive的区别
    查看>>
    MySQL和Java数据类型对应
    查看>>
    mysql和oorcale日期区间查询【含左右区间问题】
    查看>>
    MYSQL和ORACLE的一些操作区别
    查看>>
    mysql和redis之间互相备份
    查看>>
    MySQL和SQL入门
    查看>>
    mysql在centos下用命令批量导入报错_Variable ‘character_set_client‘ can‘t be set to the value of ‘---linux工作笔记042
    查看>>
    Mysql在Linux运行时新增配置文件提示:World-wrirable config file ‘/etc/mysql/conf.d/my.cnf‘ is ignored 权限过高导致
    查看>>
    Mysql在Windows上离线安装与配置
    查看>>
    MySQL在渗透测试中的应用
    查看>>
    Mysql在离线安装时启动失败:mysql服务无法启动,服务没有报告任何错误
    查看>>
    Mysql在离线安装时提示:error: Found option without preceding group in config file
    查看>>
    MySQL基于SSL的主从复制
    查看>>
    Mysql基本操作
    查看>>
    mysql基本操作
    查看>>
    mysql基本知识点梳理和查询优化
    查看>>
    mysql基础
    查看>>