《C语言都有哪些字符串处理函数?》

目录

17个字符串处理函数

1. gets()--读

2.fgets()--从指定文件内读

3.puts()--输出

4.fputs()--写入到指定文件中

5.strlen()--计算字符串长度

6.strcpy()--复制

7.strncpy()--复制前n个字符

8.strcat()--字符串连接

9.strncat()--将前n个字符连接

10.strcmp()--比较字符串大小

11.strncmp()--比较前n个字符大小

12.sprintf()

13.sscanf()

14.strchr()--查找字符

15.strstr()--查找字符串

16.strtok()--分割

17.atoi()--扫描数字


17个字符串处理函数

1. gets()--读

#include <stdio.h> 
char *gets(char *s); 

功能:从标准输入读入字符,并保存到 s 指定的内存空间,直到出现换行符或读到文件结尾为止。

参数

s:字符串首地址

返回值

成功:读入的字符串

失败:NULL

gets(str)与 scanf("%s",str)的区别:

1.gets(str)允许输入的字符串含有空格

2.scanf(“%s”,str)不允许含有空格

3.注意:由于 scanf()和 gets()无法知道字符串 s 大小,必须遇到换行符或读到 文件结尾为止才接收输入,因此容易导致字符数组越界(缓冲区溢出)的情况。

2.fgets()--从指定文件内读

#include <stdio.h> 
char *fgets(char *s, int size, FILE *stream);

功能:从 stream 指定的文件内读入字符,保存到 s 所指定的内存空间,直到出现换行字符、 读到文件结尾或是已读了 size - 1 个字符为止,最后会自动加上字符 ‘\0’ 作为字符串结束。

参数

s:字符串

size:指定最大读取字符串的长度(size - 1)

stream:文件指针,如果读键盘输入的字符串,固定写为 stdin

返回值

成功:成功读取的字符串读到文件尾

出错: NULL。

fgets()在读取一个用户通过键盘输入的字符串的时候,同时把用户输入的回车也做为字符串的一部分。通过 scanf 和 gets 输入一个字符串的时候,不包含结尾的“\n”,但通过 fgets 结尾多了“\n”。fgets()函数是安全的,不存在缓冲区溢出的问题。

3.puts()--输出

#include <stdio.h> 
int puts(const char *s);

功能 标准设备输出 s 字符串,在输出完成后自动输出一个’\n’。

参数 s:字符串首地址

返回值 成功:非负数 失败:-1

4.fputs()--写入到指定文件中

#include <stdio.h> 
int fputs(const char * str, FILE * stream);

功能: 将 str 所指定的字符串写入到 stream 指定的文件中, 字符串结束符 ‘\0’ 不写入文件。

参数

str:字符串

stream:文件指针,如果把字符串输出到屏幕,固定写为 stdout

返回值

成功:0 失败:-1

fputs()是 puts()的文件操作版本,但 fputs()不会自动输出一个’\n’。

5.strlen()--计算字符串长度

#include <string.h> 
size_t strlen(const char *s);
功能
计算指定指定字符串 s 的长度,不包含字符串结束符‘\0’参数
s:字符串首地址返回值
字符串 s 的长度,size_t 为 unsigned int 类型

 6.strcpy()--复制

#include <string.h> 
char *strcpy(char *dest, const char *src);

功能:把 src 所指向的字符串复制到 dest 所指向的空间中,’\0’也会拷贝过去。

参数

dest:目的字符串首地址

src:源字符首地址

返回值

成功:返回 dest 字符串的首地址

失败:NULL

注意:如果参数 dest 所指的内存空间不够大,可能会造成缓冲溢出的错误情况。

7.strncpy()--复制前n个字符

#include <string.h> 
char *strncpy(char *dest, const char *src, size_t n);

功能:把 src 指向字符串的前 n 个字符复制到 dest 所指向的空间中,是否拷贝结束符看指定 的长度是否包含’\0’。

参数

dest:目的字符串首地址

src:源字符首地址

n:指定需要拷贝字符串个数

返回值

成功:返回 dest 字符串的首地址

失败:NULL

8.strcat()--字符串连接

#include <string.h> 
char *strcat(char *dest, const char *src);

功能 将 src 字符串连接到 dest 的尾部,‘\0’也会追加过去

参数 dest:目的字符串首地址 src:源字符首地址

返回值 成功:返回 dest 字符串的首地址 失败:NULL

9.strncat()--将前n个字符连接

#include <string.h> 
char *strncat(char *dest, const char *src, size_t n);

功能 将 src 字符串前 n 个字符连接到 dest 的尾部,‘\0’也会追加过去

参数 dest:目的字符串首地址 src:源字符首地址 n:指定需要追加字符串个数

返回值 成功:返回 dest 字符串的首地址 失败:NULL

10.strcmp()--比较字符串大小

#include <string.h> 
int strcmp(const char *s1, const char *s2);

功能 比较 s1 和 s2 的大小,比较的是字符 ASCII 码大小。

参数 s1:字符串 1 首地址 s2:字符串 2 首地址

返回值 相等:0 大于:>0 小于:<0

11.strncmp()--比较前n个字符大小

#include <string.h> 
int strncmp(const char *s1, const char *s2, size_t n);

功能:比较 s1 和 s2 前 n 个字符的大小,比较的是字符 ASCII 码大小。

参数

s1:字符串 1 首地址

s2:字符串 2 首地址

n:指定比较字符串的数量

返回值

相等:0 大于: > 0 小于: < 0

12.sprintf()

#include <stdio.h> 
int sprintf(char *_CRT_SECURE_NO_WARNINGS, const char *format, ...);

功能 根据参数 format 字符串来转换并格式化数据,然后将结果输出到 str 指定的空间中, 直到出现字符串结束符 ‘\0’ 为止。

参数 str:字符串首地址 format:字符串格式,用法和 printf()一样

返回值 成功:实际格式化的字符个数 失败:-1

13.sscanf()

#include <stdio.h> 
int sscanf(const char *str, const char *format, ...);

功能 从 str 指定的字符串读取数据,并根据参数 format 字符串来转换并格式化数据。

参数 str:指定的字符串首地址 format:字符串格式,用法和 scanf()一样

返回值 成功:参数数目,成功转换的值的个数 失败: - 1

14.strchr()--查找字符

#include <string.h> 
char *strchr(const char *s, int c);

功能 在字符串 s 中查找字母 c 出现的位置

参数 s:字符串首地址 c:匹配字母(字符)

返回值 成功:返回第一次出现的 c 地址 失败:NULL

15.strstr()--查找字符串

#include <string.h> 
char *strstr(const char *haystack, const char *needle);

功能 在字符串 haystack 中查找字符串 needle 出现的位置

参数 haystack:源字符串首地址 needle:匹配字符串首地址

返回值 成功:返回第一次出现的 needle 地址 失败:NULL

16.strtok()--分割

#include <string.h> 
char *strtok(char *str, const char *delim);

功能

来将字符串分割成一个个片段。当 strtok()在参数 s 的字符串中发现参数 delim 中包含 的分割字符时, 则会将该字符改为\0 字符,当连续出现多个时只替换第一个为\0。

参数

str:指向欲分割的字符串

delim:为分割字符串中包含的所有字符

返回值

成功:分割后字符串首地址

失败:NULL

在第一次调用时:strtok()必需给予参数 s 字符串

往后的调用则将参数 s 设置成 NULL,每次调用成功则返回指向被分割出片 段的指针

17.atoi()--扫描数字

#include <stdlib.h> int atoi(const char *nptr);

功能

atoi()会扫描 nptr 字符串,跳过前面的空格字符,直到遇到数字或正负号才开始做转 换,而遇到非数字或字符串结束符(’\0’)才结束转换,并将结果返回返回值。

参数

nptr:待转换的字符串

返回值

成功转换后整数

类似的函数有

atof():把一个小数形式的字符串转化为一个浮点数。

atol():将一个字符串转化为 long 类型

 感谢你的阅读,希望可以帮助到你~

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

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

相关文章

带你摸透C语言相关内存函数

c语言中的小小白-CSDN博客c语言中的小小白关注算法,c,c语言,贪心算法,链表,mysql,动态规划,后端,线性回归,数据结构,排序算法领域.https://blog.csdn.net/bhbcdxb123?spm1001.2014.3001.5343 给大家分享一句我很喜欢我话&#xff1a; 知不足而奋进&#xff0c;望远山而前行&am…

【论文阅读】Vision Mamba:双向状态空间模型的的高效视觉表示学习

文章目录 Vision Mamba:双向状态空间模型的的高效视觉表示学习摘要介绍相关工作用于视觉应用的状态空间模型 方法准备视觉MambaVim块结构细节高效分析计算效率 实验图片分类语义分割目标检测和实例分割消融实验双向SSM分类设计 总结和未来工作 论文地址&#xff1a; Vision Mam…

人工智能测试开发

随着人工智能在各行各业的广泛应用&#xff0c;学习并掌握AI技术在软件测试中的应用变得至关重要。不仅能使你跟上行业的发展趋势&#xff0c;还能提升你的竞争力。而且&#xff0c;市场对具备AI测试技能的测试工程师的需求正日益增长&#xff0c;这使得掌握这些技能能够帮助你…

蓝桥杯算法训练VIP-数组查找及替换

题目 1634: 蓝桥杯算法训练VIP-数组查找及替换 时间限制: 3s 内存限制: 192MB 提交: 1629 解决: 890 题目描述 给定某整数数组和某一整数b。要求删除数组中可以被b整除的所有元素&#xff0c;同时将该数组各元素按从小到大排序。如果数组元素数值在A到Z的ASCII之间&#xff0…

C++初阶

1.缺省参数 给缺省参数的时候&#xff0c;不能声明&#xff0c;定义同时给&#xff0c;只能声明的时候给缺省参数&#xff0c;同时给程序报错&#xff1b; 2.函数重载 C语言不允许同名函数的存在&#xff0c;函数名不能相同&#xff0c;C引入函数重载&#xff0c;函数名可以…

GUI编程--PyQt5--QTabWidget

文章目录 组件使用信号样式设置 组件使用 QTabWidget 页签 信号 self._ui Ui_Sub() self._ui.setupUi(right) # 切换tab页 self._ui.tabWidget.currentChanged.connect(self.tab_slot)def tab_slot(self):cur_index self._ui.tabWidget.currentIndex()tab_name self._ui…

InstantID Zero-shot Identity-Preserving Generation in Seconds

InstantID: Zero-shot Identity-Preserving Generation in Seconds TL; DR&#xff1a;InstantID IP-Adapter (Face) ControlNet&#xff0c;实现了具有较高保真度的人脸 ID 生成。 方法 InstantID 想做到的事情是&#xff1a;给定一张参考人脸 ID 图片&#xff0c;生成该…

24计算机考研调剂 | 东北石油大学

东北石油大学智能物探团队招生宣传 考研调剂招生信息 学校:东北石油大学 专业:工学->地质资源与地质工程->矿产普查与勘探 年级:2024 招生人数:2 招生状态:正在招生中 联系方式:********* (为保护个人隐私,联系方式仅限APP查看) 补充内容 团队介绍&#xff1a; …

LeetCode543题:二叉树的直径(python3)

代码思路&#xff1a; 先递归调用左儿子和右儿子求得它们为根的子树的深度 L和 R &#xff0c;则该节点为根的子树的深度即为max(L,R)1。该节点的 dnode值为LR1 递归搜索每个节点并设一个全局变量 ans记录 dnode的最大值&#xff0c;最后返回 ans-1 即为树的直径。 # Definit…

编曲制作软件Fruity Loops Studio 21 中文版及新如何选择适合FL Studio 版本

如果你有着满腔的音乐才华&#xff0c;想要自己在家里发片吗&#xff1f;还是听 MOBY 的电子舞曲不过瘾&#xff0c;要再帮他做做 REMIX&#xff1f;有朋友会说&#xff0c;我不懂乐理&#xff0c;不懂五线谱&#xff0c;怎么制作音乐&#xff1f;这话说得很好&#xff0c;说到…

手搭手RocketMQ发送消息

消息中间件的对比 消息中间件 ActiveMQ RabbitMQ RocketMQ kafka 开发语言 java erlang java scala 单击吞吐量 万级 万级 10万级 10万级 时效性 ms us ms ms 可用性 高(主从架构) 高(主从架构) 非常高(主从架构) 非常高(主从架构) 消息中间件: acti…

Oracle PL/SQL Programming 第9章:Numbers 读书笔记

总的目录和进度&#xff0c;请参见开始读 Oracle PL/SQL Programming 第6版 本章谈3点&#xff1a; 可使用的数字数据类型如何在数字和文本间转换PL/SQL 内置数值函数 Numeric Datatypes NUMBER&#xff1a;平台无关的实现&#xff0c;适合处理货币金额PLS_INTEGER 和 BINA…