c语言的字符串函数详解

文章目录

  • 前言
  • 一、strlen求字符串长度的函数
  • 二、字符串拷贝函数strcpy
  • 三、链接或追加字符串函数strcat
  • 四、字符串比较函数strcmp
  • 五、长度受限制字符函数
  • 六、找字符串2在字符串1中第一次出现的位置函数strstr
  • 七、字符串切割函数strtok(可以切割分隔符)
  • 八、翻译错误码所对应的错误信息strerror


前言

在编程的过程中,我们经常要处理字符和字符串,为了方便操作字符和字符串,C语言标准库中提供了一系列的库函数,接下来我们就学习⼀下这些函数。


一、strlen求字符串长度的函数

size_t strlen ( const char * str )

这个函数是我们之前用的最多的函数了,所以相对之下也比较熟悉,这里也就简单地概括一下,讲下注意点,这个函数他'/0'零作为结束标志注意和sizeof的区别。他的模拟实现有三种方法http://t.csdnimg.cn/PXwTV,以前写过,就不多说了。

二.字符串拷贝函数strcpy

char* strcpy(char * destination, const char * source );

2.1使用

destination这个是目的,source这个是源头,字符拷贝的意思就是把源头的数据拷贝到目的中去。使用之前引用头文件<string.h>。

int main()
{char name[20] = { 0 };strcpy(name,"zhangsan");printf("%s",name);return 0;
}

打印的结果就是zhangsa,但是要注意,目地空间必须是可以改变的改变的,不可以为常量字符串。注意:1.它以'/0'结束。2.它会把'/0'也拷入目地空间。3.目的空间必须足够大,不然会越界。

2.2模拟实现

my_strcpy(char* dest, const char* src)
{assert(dest && src);char* ret = dest;while (src){*dest++ = *src++;}*dest = *src;//拷贝/0return ret;
}

为这个代码,他最后是要返回目的的数组,所以在开始前,我得先把他的地址拷贝起来

三.链接或追加字符串函数strcat

char* strcat(char * destination, const char * source );

3.1使用

int main()
{char arr1[20] = "hello ";char arr2[] = "world";strcat(arr1, arr2);printf("%s", arr1);return 0;
}

打印结构就是hello world,用法根之前同理,目标空间必须足够大,而且是要可修改的,目标字符串中也得有 \0,否则没办法知道追加从哪里开始。

3.2模拟实现

my_strcat(char* dest, const char* src)
{//assert(dest && src);//找到dest的/0char* ret = dest;while (*dest != '\0'){dest++;}//拷贝字符while (*src){*dest++ = *src++;}*dest = *src;//拷贝/0return ret;}

3.3字符串自己给自己追加,如何?

先说结论是不能自己给自己追加的

因为自己会把/0覆盖,导致没有/0会陷入一种死循环

四.字符串比较函数strcmp

char* strcmpchar * destination, const char * source );

4.1使用

比较字符串函数注意比较的,不是长度比的是asc码值

int main()
{char arr1[20] = "abcd";char arr2[20] = "cdf";int a=strcmp(arr1, arr2);printf("%d",a);return 0;
}

打印结果为-1,所以说如果arr1比arr2小就会返回-1,等于就会返回0,大于就会返回1。

4.2模拟实现

int my_strcmp(char* str1, const char* str2)
{//assert(str1 && str2);while (*str1 == *str2){//相等if (*str1=='\0' || *str2=='\0'){return 0;}str1++;str2++;}return (*str1 - *str2);}

五.长度受限制字符函数

以上就是长度不受限制的函数,长度受限制的函数要更加安全,在它们的后面添加数字n就可以自己去定义,strncpy,strncat,strncmp

( char * destination, const char * source, size_t num );

举一个例子:

六.找字符串2在字符串1中第一次出现的位置函数strstr

char * strstr ( const char * str1, const char * str2)

6.1使用

int main()
{char str[] = "This is a simple string";char* pch = strstr(str, "simple");if (pch == NULL){printf("不存在");}elseprintf("%s\n", pch);return 0;
}

打印结果为simple string,说明如果找到了的话它就会返回一个地址

6.2模拟实现

他的模拟实现是比较复杂的,我们要分两种情况去考虑

情况1(一次就匹配就找到了)

情况2(多次匹配才可以找到)

char* my_strstr(const char* str1, const char* str2)
{//定义3个变量,s1,s2用来比较,cur用来解决第2种情况const char* s1 = NULL;const char* s2 = NULL;const char* cur = str1;//cur不为空就一直走while (cur){s1 = str1;s2 = str2;//到了\0就停,不相等也停while(*s1!='\0' && *s2!='\0' && *s1==*s2){s1++;s2++;}//如果是s2到0了,说明找到了if (*s2 == '\0'){return cur;}//可能存在第2找情况cur++;}//说明没有找到return NULL;
}

七.字符串切割函数strtok(可以切割分隔符)

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

这个函数的使用比较难,所以我们这里之讲解它的使用。

使用

注意:strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针,strtok函数的第一个参数不为NULL,函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置。strtok函数的第一个参数为NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标记。

所以说只用一个是无法找完所以的,要配合循环语句一起使用

int main()
{char arr[] = "192.168.6.111";char* sep = ".";char* str = NULL;for (str = strtok(arr, sep); str != NULL; str = strtok(NULL, sep)){printf("%s\n", str);}return 0;
}

八.翻译错误码所对应的错误信息strerror

strerror函数可以把参数部分错误码对应的错误信息的字符串地址返回来

1.No error
2.Operation not permitted
3.No such file or directory
4.No such process
5.Interrupted function call
6.Input / output error
7.No such device or address
8.Arg list too long
9.Exec format error
10.Bad file descriptor
11.No child processes

常见的错误信息

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

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

相关文章

【C语言】分支语句(逻辑运算符与关系运算符)

文章目录 **逻辑运算符(&&、||、!)**逻辑运算符特点短路短路-逻辑与短路-逻辑或 **关系运算符&#xff08;relational expression&#xff09;**运算操作符的结合律、运算符 **选择结构/分支结构****if 语句****复合句的if语句(if...else..语句)****不良风格的程序** *…

uniapp 之 实现商品详情的锚点跳转(类似京东商品详情-点击顶部按钮跳转的对应的页面的内容区域)

类似京东商品详情-点击顶部详情跳转到页面对应的详情区域&#xff0c;点击评价跳转到页面对应的评价区域等。 照例&#xff0c;先封装方法&#xff1a; 封装方法 util.js /*** 锚点跳转&#xff08;如&#xff1a;商品详情页面跳转&#xff09;* param {string} targetId 目…

sqllab第十八关通关笔记

知识点&#xff1a; UA注入 不进行url解析&#xff0c;不能使用 %20 编码等操作出现在User-agent字段中一般为insert语句 insert 表名(字段1&#xff0c;字段2&#xff0c;。。。) values(数据1&#xff0c;数据2&#xff0c;。。。) 通过admin admin进行登录发现页面打印出了…

【中等】保研/考研408机试-二叉树相关

目录 一、基本二叉树 1.1结构 1.2前序遍历&#xff08;注意三种遍历中Visit所在的位置&#xff09; 1.2中序遍历 1.3后序遍历 二、真题实战 2.1KY11 二叉树遍历&#xff08;清华大学复试上机题&#xff09;【较难】 2.2KY212 二叉树遍历二叉树遍历&#xff08;华中科技大…

通信信号处理中的调制识别技术及其基于C++ Qt的实现

在现代通信系统中,调制技术扮演着至关重要的角色。调制是将基带信号转换为适合在信道中传输的高频信号的过程。常见的模拟调制方式有幅度调制(AM)和频率调制(FM),数字调制方式有频移键控(FSK)和相移键控(PSK)。为了实现高效、可靠的通信,接收端必须能够准确识别发送端所采用的调…

详解命令docker run -d --name container_name -e TZ=Asia/Shanghai your_image

docker run 是Docker的主要命令&#xff0c;用于从镜像启动一个新的容器。下面详细解释并举例说明 -d, --name, -e TZ 参数的用法&#xff1a; -d 或 --detach&#xff1a; 这个标志告诉Docker以守护进程&#xff08;后台&#xff09;模式运行容器。这意味着当你执行 docker ru…

前端学习笔记|JavaScript基础

JS基础 数据类型 基于动力节点视频。 Number、String、Boolean、object 强制转换 Number 强转,boolean强转(undefined、null、NaN都是转成false)&#xff0c;String强转 myAge Number("123445"); Boolean(0); String(123);parseInt、parseFloat 遇到非数字&…

Java——网络编程

网络编程基础类 InetAddress类 java.net.InetAddress类用来封装计算机的IP地址和DNS(没有端口信息),它包括一个主机名和一个ip地址,是java对IP地址的高层表示。大多数其他网络类都要用到这个类&#xff0c;包括Sorket、ServerSocker、URL、DatagramSorket、DatagramPacket等常…

15.7k stars一个实用型OCR,支持80多种语言

一个实用型 OCR,支持 80 多种语言和所有流行的书写脚本&#xff0c;包括&#xff1a;拉丁文、中文、阿拉伯文、梵文、西里尔文等。 特点 支持本地或云/API部署 准确度提高到 99% 以上 完全可定制,支持 80 多种语言 支持表格识别 二维码/条码提取识别 GitHub数据 15.7k s…

LAMP下Moodle平台安装

目录 一、虚拟机安装 二、Linux使用ubuntu 三、设置管理员root的密码: 四、注销登录 五、用root账号重新登录 六、安装vmware tools 七、更新系统 八、允许SSH客户端登录 九、实体机中安装远程管理客户端 十、实体机安装文件传输工具 十一、使用Putty登录,安装插件…

学习总结2

第二周总结 一、总结贪吃蛇制作思路 1.绘制API&#xff0c;所以需要引入graphics.h这个图形界面库。 2.游戏规则 蛇是一节一节的&#xff0c;每吃掉一个事物都会长一节蛇吃食物需要移动&#xff0c;如果需要移动那么就会有坐标的变化。蛇没吃掉一个事物都会随机产生一个食物…

鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:Column)

沿垂直方向布局的容器。 说明&#xff1a; 该组件从API Version 7开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 子组件 可以包含子组件。 接口 Column(value?: {space?: string | number}) 从API version 9开始&#xff0c;该接口…

MySQL 中的自增ID及其应用场景

在MySQL中&#xff0c;自增ID主要体现在几种不同的场景下&#xff0c;每种自增ID都有其特定用途和行为特征&#xff1a; 1. Auto-Increment ID (PRIMARY KEY AUTO_INCREMENT) 场景&#xff1a;在创建表时&#xff0c;可以为某个整数字段设置AUTO_INCREMENT属性&#xff0c;生成…

LeetCode--58

58. 最后一个单词的长度 给你一个字符串 s&#xff0c;由若干单词组成&#xff0c;单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。 单词 是指仅由字母组成、不包含任何空格字符的最大 子字符串 。 示例 1&#xff1a; 输入&#xff1a;s "Hello W…

unity学习(57)——选择角色界面--删除角色2

1.客户端添加点击按钮所触发的事件&#xff0c;在selectMenu界面中增加myDelete函数&#xff0c;当点击“删除角色”按钮时触发该函数的内容。 public void myDelete() {string message nowPlayer.id;//string m Coding<StringDTO>.encode(message);NetWorkScript.get…

Pandas中高效选择和替换操作总结

Pandas是数据操作、分析和可视化的重要工具&#xff0c;有效地使用Pandas可能具有挑战性&#xff0c;从使用向量化操作到利用内置函数&#xff0c;这些最佳实践可以帮助数据科学家使用Pandas快速准确地分析和可视化数据。 图片 在本文中&#xff0c;我们将重点介绍在DataFram…

Docker 学习笔记一

一、什么是docker Docker 是一个基于轻量级虚拟化技术的容器&#xff0c;整个项目基于Go语言开发&#xff1b;Docker是一个C/S架构&#xff0c;后端众多模块各司其职&#xff0c;docker的daemon是运行在主机上通过client可以进行通信。 docker 由三部分组成&#xff1a;镜像(…

使用Seata实现分布式事务真香!

之前分享了六种分布式事务方案&#xff1a; 本地消息表&#xff1a;如何通过本地消息表实现分布式事务 最大努力通知&#xff1a;如何使用最大努力通知实现分布式事务&#xff1f;与本地消息表区别&#xff1f; XA模式&#xff1a;用二阶段三阶段提交实现分布式事务 TCC模式…

【820复试】数据结构面试问题

文章目录 1.用循环比递归的效率高吗2.顺序表和链表的比较3.头指针和头结点的区别4.如何区分循环队列是队满还是队空&#xff1f;5.栈在通过后缀表达式求值的算法思想6.栈在递归中的应用7.队列在层次遍历中的作用8.队列在计算机系统中的应用9.矩阵的压缩存储10.串的模式匹配11.如…

解析编程中不可或缺的基础:深入了解结构体类型

精琢博客&#xff0c;希望可以给大家带来收获~ 博主主页&#xff1a;17_Kevin-CSDN博客 收录专栏&#xff1a;《C语言》 引言 在编程中&#xff0c;结构体是一种自定义的数据类型&#xff0c;它允许开发人员将不同类型的数据组合在一起&#xff0c;并为其定义相关属性和行为。…