【c语言】字符串常见函数 下

news2024/11/27 18:26:37

🎈个人主页:甜美的江
🎉欢迎 👍点赞✍评论⭐收藏
🤗收录专栏:c语言
🤝希望本文对您有所裨益,如有不足之处,欢迎在评论区提出指正,让我们共同学习、交流进步!

【c语言】字符串常见函数 下

  • 一、字符串搜索函数
    • 1.1 strchr (String Character):
    • 1.2 strrchr (String Reverse Character):
    • 1.3 strstr (String Search):
  • 二、字符串长度函数
    • 2.1 strlen (String Length):
  • 三、字符串分割函数
    • 3.1 strtok (String Tokenizer):

引言:

在C语言中,处理字符串是一项常见且重要的任务。为了有效地操作字符串,C语言提供了许多内置的字符串处理函数。

本文将介绍一些常见的C语言字符串函数,包括字符串搜索函数、字符串长度函数和字符串分割函数。

通过了解这些函数的用法和原理,你将能够更轻松地处理和操作字符串数据。

上半部分内容点这里。

【c语言】字符串常见函数 上

在这里插入图片描述

一、字符串搜索函数

当在C语言中需要在字符串中搜索特定字符或子字符串时,可以使用以下几个常见的字符串搜索函数:strchr、strrchr 和 strstr。下面将详细介绍它们的用法、示例以及注意事项。

1.1 strchr (String Character):

用法:

strchr 函数用于在字符串中查找指定字符的第一个匹配项,并返回该字符所在位置的指针。如果未找到指定字符,则返回 NULL。

示例:

#include <stdio.h>
#include <string.h>

int main() {
    char str[] = "hello world";
    char *ptr;

    ptr = strchr(str, 'o');

    if (ptr != NULL) {
        printf("Found at position: %ld\n", ptr - str);
    } else {
        printf("Not found\n");
    }

    return 0;
}

结果:

Found at position: 4

代码分析:

这段C代码首先定义了一个字符数组 str 包含字符串 “hello world”。然后,通过调用 strchr 函数,在字符串中查找字符 ‘o’ 的第一次出现的位置,并将该位置的指针赋值给 ptr 变量。

接着,通过条件判断检查 ptr 是否为 NULL,如果不是,则表示找到了字符 ‘o’,并使用 printf 函数输出其在字符串中的位置(通过指针减法计算相对位置),否则输出 “Not found”。

最后,程序返回0,表示正常执行结束。

这段代码的作用是在字符串中查找字符 ‘o’ 的第一次出现位置,并输出结果。

在给定的示例字符串 “hello world” 中,字符 ‘o’ 第一次出现在位置 4(从零开始计数),因此输出结果为 “Found at position: 4”。

注意事项:

strchr 函数只返回第一个匹配项的指针,如果需要找到所有匹配项,可以使用循环遍历字符串。

注意处理返回值为 NULL 的情况,表示未找到匹配项。

1.2 strrchr (String Reverse Character):

用法:

strrchr 函数用于在字符串中查找指定字符的最后一个匹配项,并返回该字符所在位置的指针。如果未找到指定字符,则返回 NULL。

示例:

#include <stdio.h>
#include <string.h>

int main() {
    char str[] = "hello world";
    char *ptr;

    ptr = strrchr(str, 'o');

    if (ptr != NULL) {
        printf("Found at position: %ld\n", ptr - str);
    } else {
        printf("Not found\n");
    }

    return 0;
}

结果:

 Found at position: 7

代码分析:

这段C代码首先定义了一个字符数组 str 包含字符串 “hello world”。

然后,通过调用 strrchr 函数,在字符串中从右往左查找字符 ‘o’ 的最后一次出现的位置,并将该位置的指针赋值给 ptr 变量。

接着,通过条件判断检查 ptr 是否为 NULL,如果不是,则表示找到了字符 ‘o’,并使用 printf 函数输出其在字符串中的位置(通过指针减法计算相对位置),否则输出 “Not found”。

最后,程序返回0,表示正常执行结束。

这段代码的作用是在字符串中查找字符 ‘o’ 的最后一次出现位置,并输出结果。

在给定的示例字符串 “hello world” 中,字符 ‘o’ 最后一次出现在位置 7(从零开始计数),因此输出结果为 “Found at position: 7”。

注意事项:

strrchr 函数从字符串的末尾开始搜索,找到第一个匹配项后即停止搜索,返回该匹配项的指针。

处理返回值为 NULL 的情况,表示未找到匹配项。

1.3 strstr (String Search):

用法:

strstr 函数用于在字符串中查找指定子字符串的第一个匹配项,并返回该子字符串的指针。如果未找到子字符串,则返回 NULL。

示例:

#include <stdio.h>
#include <string.h>

int main() {
    char str[] = "hello world";
    char *ptr;

    ptr = strstr(str, "lo");

    if (ptr != NULL) {
        printf("Found at position: %ld\n", ptr - str);
    } else {
        printf("Not found\n");
    }

    return 0;
}

结果:

 Found at position: 3

代码分析:

这段C代码首先定义了一个字符数组 str 包含字符串 “hello world”。

然后,通过调用 strstr 函数,在字符串中查找子字符串 “lo” 的第一次出现的位置,并将该位置的指针赋值给 ptr 变量。

接着,通过条件判断检查 ptr 是否为 NULL,如果不是,则表示找到了子字符串 “lo”,并使用 printf 函数输出其在字符串中的位置(通过指针减法计算相对位置),否则输出 “Not found”。

最后,程序返回0,表示正常执行结束。

这段代码的作用是在字符串中查找子字符串 “lo” 的第一次出现位置,并输出结果。

在给定的示例字符串 “hello world” 中,子字符串 “lo” 第一次出现在位置 3(从零开始计数),因此输出结果为 “Found at position: 3”。
注意事项:

strstr 函数会从字符串中找到第一个匹配子字符串的位置,并返回该子字符串的指针。

处理返回值为 NULL 的情况,表示未找到匹配项。

这些函数是在C语言中常用的字符串搜索工具,可以根据具体需求选择合适的函数来实现字符串搜索功能。

二、字符串长度函数

当在C语言中需要获取字符串的长度时,可以使用 strlen 函数。下面将详细介绍 strlen 函数的用途、用法、示例以及注意事项。

2.1 strlen (String Length):

用途:

strlen 函数用于计算字符串的长度,即字符串中的字符个数,不包括字符串结束符(‘\0’)。

用法:

函数原型如下:

size_t strlen(const char *str);

参数 str:要计算长度的字符串。

返回值:返回字符串的长度。

示例:

#include <stdio.h>
#include <string.h>

int main() {
    char str[] = "hello world";
    size_t length;

    length = strlen(str);

    printf("Length of the string: %zu\n", length);

    return 0;
}

结果:

Length of the string: 11

代码分析:

这段C代码首先定义了一个字符数组 str 包含字符串 “hello world”。

然后,通过调用 strlen 函数获取字符串的长度,并将结果赋值给 length 变量。

接着,通过使用 printf 函数输出字符串的长度,格式化字符串中 %zu 是用于打印 size_t 类型的长度。

最后,程序返回0,表示正常执行结束。

这段代码的主要功能是计算并输出字符串 “hello world” 的长度。

在给定的示例中,字符串的长度为11,因此输出结果为 “Length of the string: 11”。

注意事项:

strlen 返回的是 size_t 类型的无符号整数,因此使用 %zu 格式说明符打印结果。

注意字符串中的结束符 \0 不计入计算长度,即返回值为字符串中字符的实际个数。

这是一个简单而常用的字符串操作函数,用于获取字符串的长度。在使用时,需要注意字符串的结尾必须是空字符 \0。如果字符串没有正确以空字符结尾,strlen 可能会导致未定义的行为。

因此,在使用 strlen 时,确保字符串是以空字符正确终止的。

三、字符串分割函数

strtok 函数用于在C语言中分割字符串。它允许你将一个字符串拆分成多个子字符串,根据指定的分隔符进行分割。
下面将详细介绍 strtok 函数的用途、用法、示例以及注意事项。

3.1 strtok (String Tokenizer):

用途:

strtok 用于将字符串拆分成一系列的标记(tokens),这些标记由用户指定的分隔符来定义。

每次调用 strtok,它返回下一个标记,直到字符串结束或者再没有其他标记为止。

用法:

函数原型如下:

char *strtok(char *str, const char *delimiters);

参数 str:要分割的字符串,第一次调用时传入待分割的字符串,后续调用传入 NULL。

参数 delimiters:分隔符字符串,包含所有可能的分隔符。

返回值:返回下一个标记的指针,如果没有更多标记则返回 NULL。

示例:

#include <stdio.h>
#include <string.h>

int main() {
    char str[] = "apple,orange,banana";
    const char delimiters[] = ",";

    // 第一次调用
    char *token = strtok(str, delimiters);

    while (token != NULL) {
        printf("Token: %s\n", token);

        // 后续调用,传入NULL表示继续使用同一字符串
        token = strtok(NULL, delimiters);
    }

    return 0;
}

结果:

Token: apple
Token: orange
Token: banana

代码分析:

这段C代码首先定义了一个字符数组 str 包含字符串 “apple,orange,banana”,以及一个包含分隔符 “,” 的字符数组 delimiters。

然后,通过第一次调用 strtok 函数,将字符串 str 按照分隔符 “,” 进行分割,并返回第一个分割后的子字符串的指针,并将该指针赋值给 token 变量。

接着,通过一个 while 循环,不断检查 token 是否为 NULL,如果不是,则表示仍有未处理的子字符串,依次输出每个子字符串,并通过后续调用 strtok(NULL, delimiters)

继续获取下一个分割后的子字符串,直到所有子字符串都被处理完毕。

最后,程序返回0,表示正常执行结束。

这段代码的作用是将字符串 “apple,orange,banana” 按照逗号进行分割,并输出每个分割后的子字符串。

输出结果为每个子字符串(apple、orange、banana)分别占一行。

注意事项:

strtok 在处理字符串时会修改原始字符串,将分隔符替换为 \0,因此需要谨慎使用,特别是当原始字符串是常量字符串时。

在多线程环境下,strtok 是不可重入的,因为它使用了静态变量来记录当前的解析位置。

如果字符串中有连续的分隔符,strtok 会将它们视为一个分隔符处理,因此可能返回空标记

四 总结:

本文介绍了C语言中的一些常见字符串函数,包括字符串搜索函数、字符串长度函数和字符串分割函数。

通过学习这些函数,我们可以在C语言中更加灵活和高效地处理字符串数据。

字符串搜索函数 strchr、strrchr 和 strstr 可以帮助我们在字符串中查找特定字符或子字符串的位置。

字符串长度函数 strlen 能够准确地计算字符串的长度,为字符串操作提供了基础。

字符串分割函数 strtok 则能够将字符串按照指定的分隔符进行分割,提取出其中的子字符串。

通过掌握这些字符串函数的使用方法,我们可以更加高效地编写C语言程序,并处理各种字符串操作需求。

这篇文章到这就结束啦

谢谢大家的阅读!

如果觉得这篇博客对你有用的话,别忘记三连哦。

我是甜美的江,让我们我们下次再见

在这里插入图片描述

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1448590.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

面试:大数据和深度学习之间的关系是什么?

大数据与深度学习之间存在着紧密的相互关系&#xff0c;它们在当今技术发展中相辅相成。 大数据的定义与特点:大数据指的是规模(数据量)、多样性(数据类型)和速度(数据生成及处理速度)都超出了传统数据处理软件和硬件能力范围的数据集。它具有四个主要特点&#xff0c;通常被称…

2024年智能算法优化PID参数,ITAE、ISE、ITSE、IAE四种适应度函数随意切换,附MATLAB代码...

PID 参数整定就是确定比例系数&#xff08;Kp &#xff09;、积分系数&#xff08;Ki&#xff09;和微分系数&#xff08;Kd &#xff09;的过程&#xff0c;以便使 PID 控制器能够在系统中实现稳定、快速、准确的响应。 本期的主题 采用四种2024年的智能优化算法优化PID的三个…

ros自定义msg记录

文章目录 自定义msg1. 定义msg文件2. 修改 package.xml3. 修改 CMakeLists.txt4. message_publisher.py5. message_subscriber.py6. 运行 catkin build 测试 自定义msg ros 版本&#xff1a;kinetic 自定义test包的文件结构如下 |-- test | |-- CMakeLists.txt | |-- msg…

基于Spring Boot的美容院管理系统设计与实现,计算机毕业设计(带源码+论文)

源码获取地址&#xff1a; 码呢-一个专注于技术分享的博客平台一个专注于技术分享的博客平台,大家以共同学习,乐于分享,拥抱开源的价值观进行学习交流http://www.xmbiao.cn/resource-details/1757434902285987841

算法学习——LeetCode力扣回溯篇2

算法学习——LeetCode力扣回溯篇2 40. 组合总和 II 40. 组合总和 II - 力扣&#xff08;LeetCode&#xff09; 描述 给定一个候选人编号的集合 candidates 和一个目标数 target &#xff0c;找出 candidates 中所有可以使数字和为 target 的组合。 candidates 中的每个数字…

Spring 中修改 Banner

大家好我是苏麟 , 今天聊一个有意思的东西 . Banner 启动 Spring时&#xff0c;几乎总是能在控制台上方看到如下横幅&#xff0c;这个也叫字符画、英文ASCII艺术字 设置Banner的网站 http://www.network-science.de/ascii/ http://patorjk.com/software/taag/ 在创建resources下…

(免费领源码)Java#mysql牙科诊所预约系统75174-计算机毕业设计项目选题推荐

摘 要 随着互联网时代的到来&#xff0c;同时计算机网络技术高速发展&#xff0c;网络管理运用也变得越来越广泛。因此&#xff0c;建立一个B/S结构的牙科诊所预约系统&#xff0c;会使牙科诊所预约系统的管理工作系统化、规范化&#xff0c;也会提高平台形象&#xff0c;提高管…

Flaurm实现中文搜索

目录 摘要需求本文涉及环境情况如下解决方案最终效果文章其他链接&#xff1a; 摘要 Flarum本身对中文支持并不理想&#xff0c;但随着版本更新&#xff0c;逐渐加强了对中文的优化。然而在1.8.5版本&#xff0c;却还是不支持中文搜索网站文章内容。作者在检索了全网教程&#…

Hive on Spark配置

前提条件 1、安装好Hive&#xff0c;参考&#xff1a;Hive安装部署-CSDN博客 2、下载好Spark安装包&#xff0c;链接&#xff1a;https://pan.baidu.com/s/1plIBKPUAv79WJxBSbdPODw?pwd6666 3、将Spark安装包通过xftp上传到/opt/software 安装部署Spark 1、解压spark-3.3…

【Typora】markdown神器之Typora无限使用安装与基本操作教程

&#x1f33c;一、概述 Typora是一款轻量级的Markdown编辑器&#xff0c;它提供了简洁的界面和直观的操作方式&#xff0c;专注于让用户更加专注于写作。Typora支持实时预览功能&#xff0c;用户在编辑Markdown文档时可以即时看到最终的样式效果&#xff0c;这有助于提高写作效…

基于CU,PO,RD,IPO矩阵图分析数据资产-自创

术语 数据资产&#xff1a;数据资产是具有价值的数据资源。没有价值的数据资源&#xff0c;通过采集&#xff0c;整理&#xff0c;汇总等加工后&#xff0c;也可以成为具有直接或间接价值的数据资产。传统企业逐渐数字化转型&#xff0c;尤其是互联网企业&#xff0c;都十分重视…

pm2启动的node项目访问不了,npm start却可以访问

netstat -ntlp输入该命令&#xff0c;查看启动的服务端口是否有被监听到&#xff0c;如3001&#xff0c;4000之类的&#xff0c;是node项目启动时候自己配的那个&#xff0c; 若没有&#xff0c;则执行 pm2 delete [app-id/app-name] 先删除启动的这个项目 例如pm2 delete my…

猫头虎分享已解决Bug || TypeError: Cannot read property ‘length‘ of undefined ‍

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

黑马Java——集合进阶(不可变集合、Stream流、方法引用)

目录 一、不可变集合 1、创建不可变集合的应用场景 2、创建不可变集合的书写格式 2.1、不可变的List集合 2.2、不可变的Set集合 2.3、不可变的Map集合 3、小结 二、Stream流 1、体验Stream流的作用 2、Stream流的思想 3、Stream流的使用步骤 3.1、单列集合获取Strea…

1232.缀点成线(Java)

题目描述&#xff1a; 给定一个数组 coordinates &#xff0c;其中 coordinates[i] [x, y] &#xff0c; [x, y] 表示横坐标为 x、纵坐标为 y 的点。请你来判断&#xff0c;这些点是否在该坐标系中属于同一条直线上。 输入&#xff1a; coordinates [[1,2],[2,3],[3,4],[4,5]…

[计算机提升] 备份系统:设置备份

6.5 备份系统&#xff1a;设置备份 1、进入到控制面板系统和安全\备份和还原&#xff0c;点击右侧的设置备份&#xff1a; 2、在弹出的设置备份对话框中&#xff0c;选择要保存的位置&#xff0c;点击下一步开始备份。 3、选择要备份的内容。根据需要选择即可。这种备份的…

Linux_动静态库

动态库 静态库 刚开始学编程时&#xff0c;需要下载一个环境&#xff08;vs2019&#xff09;&#xff0c;这个环境包括编译器和标准库&#xff0c;标准头文件。那么什么是库呢&#xff0c;库和头文件有什么关系呢&#xff1f; 头文件里面放的函数声明&#xff0c;库文件里面放…

MacOS - M1芯片 Mac 在“恢复”模式中启用系统扩展教程

部分软件需要开启系统扩展才能正常使用&#xff0c;但是默然M1芯片的Mac不能直接打开系统扩展&#xff0c;如下两图。 若要启用系统扩展&#xff0c;您需要在“恢复”环境中修改安全性设置。 若要执行此操作&#xff0c;请将系统关机&#xff0c;然后按住触控ID或电源按钮以开…

中国判决生效,诺基亚全面与中国手机签署授权协议,降低专利费

日前媒体报道指诺基亚与中国两家手机企业都签署了专利授权协议&#xff0c;全面结束诉讼&#xff0c;而这一切正是在OPPO于去年底在重庆法院就OPPO与诺基亚的专利费诉讼问题&#xff0c;做出裁决之后&#xff0c;要求诺基亚按公平、公正等合理收费原则收取专利费。 这几年诺基亚…

猫头虎分享已解决Bug || ImportError: cannot import name ‘relu‘ from ‘keras.layers‘

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …