C语言中常用的字符串处理函数(strlen、strcpy、strcat、strcmp)

文章目录

  • 写在前面
  • 1. strlen
    • 1.1 函数介绍
    • 1.2 模拟实现
  • 2. strcpy
    • 2.1 函数介绍
    • 2.2 模拟实现
  • 3. strcat
    • 3.1 函数介绍
    • 3.2 模拟实现
  • 4. strcmp
    • 4.1 函数介绍
    • 4.2 模拟实现

写在前面

本篇文章介绍了C语言中常用的字符串处理函数,包括strlen、strcpy、strcat和strcmp。文章中,对这几个函数进行了详细的解释和示例演示,并进行了模拟实现。

1. strlen

1.1 函数介绍

函数原型:

size_t strlen ( const char * str );
  • str:要计算长度的字符串的指针。

strlen函数是一个用于计算字符串长度的函数,它从指定的字符串起始位置开始,逐个字符地计算,直到遇到字符串结尾的 \0 为止。它返回的是字符串中\0之前的字符个数,不包括\0。
关于strlen需要注意以下几点:

  • 参数指向的字符串必须要以 \0结束,否则strlen求得的结果是未知的。
  • 注意函数的返回值为size_t,是无符号的( 易错)。

以下代码,展示了如何使用 strlen 函数来计算字符串的长度:

#include <stdio.h>
#include <string.h>int main() {const char* str = "Hello World!";size_t len = strlen(str);printf("字符串长度:%d\n", len);return 0;
}

1.2 模拟实现

strlen函数的模拟实现(3种方法):

  1. 递归求字符串长度。
#include <stdio.h>
#include <assert.h>size_t my_strlen(const char* str)
{assert(str);if (*str == '\0'){return 0;}return 1 + my_strlen(str+1);	
}int main() {const char* str = "Hello World!";size_t len = my_strlen(str);printf("字符串长度:%d\n", len);return 0;
}
  1. 计数器方法求字符串长度。
#include <stdio.h>
#include <assert.h>size_t my_strlen(const char* str)
{assert(str);size_t count = 0;while (*str++){count++;}return count;
}int main() {const char* str = "Hello World!";size_t len = my_strlen(str);printf("字符串长度:%d\n", len);return 0;
}
  1. 指针 - 指针求字符串长度。
#include <stdio.h>
#include <assert.h>size_t my_strlen(const char* str)
{assert(str);const char* _str = str;while (*str){str++;}return str - _str;
}int main() {const char* str = "Hello World!";size_t len = my_strlen(str);printf("字符串长度:%d\n", len);return 0;
}

2. strcpy

2.1 函数介绍

函数原型:

char * strcpy ( char * destination, const char * source );
  • destination:目标字符串的指针,即将源字符串的内容复制到这个字符串中。
  • source:源字符串的指针,即要复制的字符串。

strcpy是一个用于完成字符串拷贝的函数,函数将源字符串的内容复制到目标字符串中,直到遇到源字符串的结尾的 \0 为止。复制完成后,函数返回目标字符串的起始地址。
关于strcpy需要注意以下几点:

  • 源字符串必须以 ‘\0’ 结束。
  • 会将源字符串中的 ‘\0’ 拷贝到目标空间。
  • 目标空间必须足够大,以确保能存放源字符串。
  • 目标空间必须可变

以下代码,展示了如何使用 strcpy 函数来完成字符串拷贝:

#include <stdio.h>
#include <string.h>int main()
{char dest[20];//目标字符串数组const char* src = "hello word!";//源字符串//使用strcpy函数,将源字符串拷贝到目标字符串strcpy(dest, src);printf("目标字符串:%s\n", dest);return 0;
}

2.2 模拟实现

strcpy模拟实现:

  • 使用循环遍历 src 字符串中的每个字符。
  • 在循环中,将 src 字符串的每个字符复制到 dest 字符串的对应位置,包括结尾的 \0。
  • 循环直到遇到 src 字符串的 \0,然后结束循环。
  • 返回 dest字符串的起始地址,表示复制完成。
#include <stdio.h>
#include <assert.h>
//模拟实现
char* my_strcpy(char* dest, const char* src)
{assert(dest && src);//保留目标字符串起始地址char* _dest = dest;//逐个字符进行拷贝while (*dest++ = *src++){;}return _dest;
}
int main()
{char dest[20];const char* src = "hello word!";my_strcpy(dest, src);printf("目标字符串:%s\n", dest);return 0;
}

3. strcat

3.1 函数介绍

函数原型:

char * strcat ( char * destination, const char * source );
  • destination:目标字符串的指针,即要将源字符串追加到这个字符串的末尾。
  • source:源字符串的指针,即要追加到目标字符串末尾的字符串。

strcat是一个用于完成字符串追加的函数,它将源字符串的内容追加到目标字符串的末尾,直到遇到源字符串的 \0 为止。追加完成后,函数返回目标字符串的起始地址,并且目标字符串将包含原始内容以及追加内容,且以结尾\0 结束。
关于strcat需要注意以下几点:

  • 源字符串必须以 ‘\0’ 结束。
  • 目标空间必须有足够的大,能容纳下源字符串的内容。
  • 目标空间必须可修改。

以下代码,展示了如何使用 strcat 函数来追加字符串:

#include <stdio.h>
#include <string.h>int main() {char dest[20] = "Hello, ";const char* src = "World!";  // 源字符串// 使用 strcat 追加源字符串到目标字符串strcat(dest, src);printf("目标字符串:%s\n", dest);return 0;
}

3.2 模拟实现

strcat模拟实现:
实现思路:

  • 使用循环找到 dest字符串中 \0 的位置。
  • 使用循环,将 src字符串的每个字符从dest字符串\0的位置依次往后追加(包括src中\0),直到遇到 src 字符串中的 \0。
  • 返回 dest字符串的起始地址,表示追加完成。
#include <stdio.h>
#include <assert.h>
//模拟实现
char* my_strcat(char* dest, const char* src)
{assert(dest && src);char* _dest = dest;//找末尾\0while (*dest){dest++;}//从目标字符串\0位置开始往后追加while (*dest++ = *src++){;}return _dest; 
}int main()
{const char* src = "word!";// 源字符串char dest[30] = "hello ";my_strcat(dest, src);printf("%s\n", dest);return 0;
}

4. strcmp

4.1 函数介绍

函数原型:

int strcmp ( const char * str1, const char * str2 );
  • str1:要比较的第一个字符串的指针。
  • str2:要比较的第二个字符串的指针。

strcmp 是一个字符串比较函数,用于比较两个字符串的内容。该函数返回一个整数值,表示比较的结果。
标准规定:

  • 第一个字符串大于第二个字符串,则返回大于0的数字。
  • 第一个字符串等于第二个字符串,则返回0。
  • 第一个字符串小于第二个字符串,则返回小于0的数字。

关于strcmp需要注意以下几点:

  • strcmp 函数是区分大小写的,因此大写字母和小写字母被认为是不同的字符。
  • 在比较字符串时,要确保字符串以\0 结尾,否则可能会导致未定义行为。

以下代码,展示了如何使用 strcmp 函数来进行字符串比较:

#include <stdio.h>
#include <string.h>int main() {const char *str1 = "abcdef";const char *str2 = "abcdeg";int res = strcmp(str1, str2);if (res < 0) {printf("%s 小于 %s\n", str1, str2);} else if (res == 0){printf("%s 等于 %s\n", str1, str2);} else {printf("%s 大于 %s\n", str1, str2);}return 0;
}

4.2 模拟实现

strcmp模拟实现:
实现思路:

  • 使用循环遍历 str1 和 str2 字符串中的每个字符,同时比较它们的对应字符。如果同时遍历到\0的位置循环都没结束,表示两个字符串相等,返回0。
  • 在循环中,如果发现字符不相等,则返回它们的差值(ASCII码值之差)。
#include <stdio.h>
#include <assert.h>
//模拟实现
int my_strcmp(const char* str1, const char* str2)
{assert(str1 && str2);//使用循环遍历 str1 和 str2,同时比较它们的对应字符while (*str1 == *str2){if (*str1 == '\0'){return 0;}str1++;str2++;}//发现字符不相等,则返回它们的差值return *str1 - *str2;
}int main() {const char *str1 = "abcdeg";const char *str2 = "abcdef";int res = my_strcmp(str1, str2);if (res < 0){printf("%s 小于 %s\n", str1, str2);}else if (res == 0){printf("%s 等于 %s\n", str1, str2);}else {printf("%s 大于 %s\n", str1, str2);}return 0;
}

至此,本片文章就结束了,若本篇内容对您有所帮助,请三连点赞,关注,收藏支持下。
创作不易,白嫖不好,各位的支持和认可,就是我创作的最大动力,我们下篇文章见!
如果本篇博客有任何错误,请批评指教,不胜感激 !
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[开源]基于流程编排的自动化测试工具,插件驱动,测试无限可能

一、开源项目简介 流程编排&#xff0c;插件驱动&#xff0c;测试无限可能 一款基于流程编排的自动化测试工具 二、开源协议 使用Apache-2.0开源协议 三、界面展示 四、功能概述 在软件开发旅程中&#xff0c;测试流程的管理和执行常常是复杂且耗时的挑战。传统测试工具主…

云原生Kubernetes:K8S集群版本升级(v1.20.15 - v1.22.14)

目录 一、理论 1.K8S集群升级 2.集群概况 3.升级集群&#xff08;v1.21.14&#xff09; 4.验证集群&#xff08;v1.21.14&#xff09; 5.升级集群&#xff08;v1.22.14&#xff09; 6.验证集群 (v1.22.14) 二、实验 1.升级集群&#xff08;v1.21.14&#xff09; 2.验…

JAVA学习第一天,java的运行方式

对未来很迷茫&#xff0c;不知道以后能出去干什么&#xff0c;好像掌握的东西很少&#xff0c;从今天开始学习学习java吧&#xff0c;让自己充实起来&#xff0c;记录一下。 jav…

python结合excel数据轻松实现接口自动化测试

在刚刚进入测试行业的时候&#xff0c;最开始也是做功能测试&#xff0c;我想很多伙伴和我一样&#xff0c;觉得自动化测试都很高端&#xff0c;很神秘。迫不及待的想去学习作自动化测试。 以前比较常用数据库python做自动化&#xff0c;后面发现excel个人觉得更加适合&#x…

js的indexOf方法

一、数组调用 indexOf() 方法可返回数组中某个指定的元素位置。 该方法将从头到尾地检索数组&#xff0c;看它是否含有对应的元素。开始检索的位置在数组 start 处或数组的开头&#xff08;没有指定 start参数时&#xff09;。如果找到一个 item&#xff0c;则返回 item 的第一…

新手如何快速上手HTTP爬虫IP?

对于刚接触HTTP爬虫IP的新手来说&#xff0c;可能会感到有些困惑。但是&#xff0c;实际上HTTP爬虫IP并不复杂&#xff0c;只要掌握了基本的操作步骤&#xff0c;就可以轻松使用。本文将为新手们提供一个快速上手HTTP爬虫IP的入门指南&#xff0c;帮助您迅速了解HTTP爬虫IP的基…

帆软报表-SQL片段报错处理

当发现好端端的 SQL 片段&#xff0c;在数据库命令行正常运作、但是在帆软报表预览各种报错的时候&#xff1a;请先停止复制你的 SQL 片段。 然后&#xff0c;在【帆软报表的数据源编辑器中】&#xff0c;【全部逐个手敲】一遍你需要的字段和逻辑。记得点击保存。帆软报表版本 …

新闻软文稿件媒体发布怎么做?纯干货

新闻软文稿件需要投放在正确的媒体上&#xff0c;才能获得更好的宣传推广效果&#xff0c;新闻软文稿件媒体发布怎么做&#xff1f;今天伯乐网络传媒就来给大家讲解一下&#xff0c;纯干货&#xff0c;建议收藏起来慢慢看。 一、媒体选择与分析 1. 确定目标媒体 在进行新闻软…

吃瓜神奇!企查查、天眼查、天眼销,到底哪家强?

最近&#xff0c;我发现很多人在讨论查企业信息的工具&#xff0c;什么企查查、天眼查、天眼销等&#xff0c;到底哪家强呢&#xff1f; 首先&#xff0c;我们来简单了解一下这些工具。企查查是一款可以帮助用户查询企业信息的工具&#xff0c;通过输入关键词&#xff0c;可以搜…

在Android平板上使用code-server公网远程Ubuntu服务器编程

文章目录 1.ubuntu本地安装code-server2. 安装cpolar内网穿透3. 创建隧道映射本地端口4. 安卓平板测试访问5.固定域名公网地址6.结语 1.ubuntu本地安装code-server 准备一台虚拟机,Ubuntu或者centos都可以&#xff0c;这里以VMwhere ubuntu系统为例 下载code server服务,浏览器…

代码随想录算法训练营第五十九天 |647. 回文子串、516.最长回文子序列、动态规划总结篇

一、647. 回文子串 题目链接/文章讲解&#xff1a;代码随想录 思考&#xff1a; 1.确定dp数组&#xff08;dp table&#xff09;以及下标的含义 如果本题定义dp[i] 为 下标i结尾的字符串有 dp[i]个回文串的话&#xff1a; 会发现很难找到递归关系&#xff0c;dp[i] 和 dp[i-1]…

SPA项目之主页面--数据表格的增删改查

SPA项目之主页面--数据表格的增删改查 一.增删改查1.样式准备2.增加3.删除4.修改5.查询二.表单验证1.在表单中使用验证规则 一.增删改查 1.样式准备 <template><div class"books" style"padding: 20px;"><el-form :inline"true"…