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

news2024/10/2 17:18:01

目录

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.coloradmin.cn/o/1504956.html

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

相关文章

Paimon 与 Spark 的集成(二):查询优化

Paimon Apache Paimon (incubating) 是一项流式数据湖存储技术&#xff0c;可以为用户提供高吞吐、低延迟的数据摄入、流式订阅以及实时查询能力。Paimon 采用开放的数据格式和技术理念&#xff0c;可以与 Flink / Spark / Trino 等诸多业界主流计算引擎进行对接&#xff0c;共…

视频远程监控平台EasyCVR集成后播放只有一帧画面的原因排查与解决

智慧安防视频监控平台EasyCVR能在复杂的网络环境中&#xff08;专网、局域网、广域网、VPN、公网等&#xff09;将前端海量的设备进行统一集中接入与视频汇聚管理&#xff0c;平台可支持的接入协议包括&#xff1a;国标GB28181、RTSP/Onvif、RTMP&#xff0c;以及厂家的私有协议…

增量式编码器与绝对值编码器基础详解

文章目录 1 使用什么样的电信号来表示旋转和角度信息?1.1 表示相对角度的增量法1.2 表示绝对角度的绝对方法1.3 用脉冲信号表示绝对角度的伪绝对法2 相对角和绝对角的优缺点3 总结1 使用什么样的电信号来表示旋转和角度信息? 在第二部分中,我们解释了旋转和角度信息大致分为…

C++程序设计-第六/七/八章 运算符重载/包含与继承/虚函数和多态性【期末复习|考研复习】

前言 总结整理不易&#xff0c;希望大家点赞收藏。 给大家整理了一下C程序设计中的重点概念&#xff0c;以供大家期末复习和考研复习的时候使用。 C程序设计系列文章传送门&#xff1a; 第一章 面向对象基础 第四/五章 函数和类和对象 第六/七/八章 运算符重载/包含与继承/虚函…

Qt之输入框带自动补全提示功能

这个功能主要是提升人机交互的体验,在输入信息时,自动读取历史信息,协助用户自动补全信息,帮助用户快速输入。 一、使用的控件 使用QComboBox代替传统文本输入框,同时将其属性改为可编辑。 二、使用方式 可以不输入信息,下拉选择项:代码中使用QStringList作为提示信息…

汽车协议学习

ⅠOBD 1.OBD接口 OBD有16个引脚&#xff0c;每个引脚的电压不同&#xff08;可以对应不同的协议&#xff09; 车端&#xff1a; 16- 9 (短一点点的) 8-1 &#xff08;长一点的&#xff09; 2.基于OBDⅡ的通信协议 CAN &#xff08;ISO-15765&am…

如何基于 esp-at 固件测试 TCP (UART 转 WiFi 透传)吞吐?

测试工具&#xff1a; windows/Ubuntu/Android&#xff08;电脑或手机与 ESP 开发板连接相同路由器&#xff09;iperf2 工具ESP 系列的开发板USB-TTL 串口调试工具路由器 测试固件&#xff1a; AT 固件 AT 固件硬件接线说明 不同环境下的 Iperf 工具安装说明 Iperf 工具用于…

用C语言执行SQLite3的gcc编译细节

错误信息&#xff1a; /tmp/cc3joSwp.o: In function main: execSqlite.c:(.text0x100): undefined reference to sqlite3_open execSqlite.c:(.text0x16c): undefined reference to sqlite3_exec execSqlite.c:(.text0x174): undefined reference to sqlite3_close execSqlit…

部署LVS负载均衡集群架构

目录 一、ipvsadm 工具 二、NAT模式下部署LVS负载均衡 1、部署NFS共享存储服务器 1.1 安装NFS软件 1.2 新建共享目录和站点文件 1.3 设置共享策略 2、部署节点服务器1 2.1 安装并启动nginx软件 2.2 挂载共享目录到网页站点目录 2.3 修改网关 3、部署节点服务器2 3.…

植物病害识别:YOLO甘蔗叶片病害识别分类数据集

YOLO甘蔗叶片病害识别数据集, 包含尾孢菌叶斑病&#xff0c;眼斑病&#xff0c;健康&#xff0c;红腐病&#xff0c;锈病&#xff0c;黄叶病6个常见病类别&#xff0c;3300多张图像&#xff0c;yolo标注完整&#xff0c;全部原始图像&#xff0c;未应用增强。 适用于CV项目&…

GEE错误——Landsat9数据集进行去云操作后显示白板

问题 我遇到了一些有关 Landsat9 图像中的云遮蔽和图像处理的问题。我正在分享我所使用的代码以及我感兴趣的区域(资产)。请帮我解决这个问题。我是一名 GEE 学习者。问题:最终图像在大面积上有云状覆盖。 这里我们查看了搜索出的代码发现并不是没有数据集导致的,该区域有…

【Java探索之旅】数据类型与变量,字面常量,整型变量

&#x1f3a5; 屿小夏 &#xff1a; 个人主页 &#x1f525;个人专栏 &#xff1a; Java入门到精通 &#x1f304; 莫道桑榆晚&#xff0c;为霞尚满天&#xff01; 文章目录 &#x1f4d1;前言一、字面常量二、数据类型三、变量3.1 变量概念3.2 语法格式 四、整型变量4.1 整型变…

【C++ vector 类】

1. 标准库中的vector类 vector 类 的介绍&#xff1a; 注意&#xff1a; 1. vector是表示可变大小数组的序列容器。 2. 就像数组一样&#xff0c;vector 也采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素进行访问&#xff0c;和数组一样高效。但是…

seo蜘蛛池的概念!蚂蚁SEO

蜘蛛池是一种特殊的网络营销技术&#xff0c;它的主要作用是吸引搜索引擎爬虫&#xff0c;提高网站的收录和排名&#xff0c;从而增加网站的流量和曝光度。 蚂蚁SEO是一个SEO工具&#xff0c;可以帮助您提高网站权重&#xff0c;吸引更多的搜索引擎爬虫&#xff0c;提高网站的…

物联网云原生云边协同

文章目录 一、物联网平台设计1.物联网平台设计2.物联网平台实现 二、部署环境1.节点配置2.版本信息 三、物联网平台部署1.部署 Kubernetes 集群2.部署 KubeEdge3.部署 ThingsBoard 集群4.部署 ThingsBoard Edge4.1.创建 Edge 实例4.2.部署 PostgreSQL4.3.创建数据库4.4.部署 Th…

Linux之生产消费者模型

(&#xff61;&#xff65;∀&#xff65;)&#xff89;&#xff9e;嗨&#xff01;你好这里是ky233的主页&#xff1a;这里是ky233的主页&#xff0c;欢迎光临~https://blog.csdn.net/ky233?typeblog 点个关注不迷路⌯▾⌯ 我们在条件满足的时候&#xff0c;唤醒指定的线程&a…

unity学习(53)——选择角色界面--分配服务器返回的信息

好久没写客户端了&#xff0c;一上手还不太适应 1.经过测试&#xff0c;成功登陆后&#xff0c;客户端请求list_request&#xff0c;成功返回&#xff0c;如下图&#xff1a; 可见此时model第三个位置的参数是1.也成功返回了所有已注册角色的信息。 2.之前已知创建的角色信息…

计算机服务器中了locked勒索病毒怎么解密,locked勒索病毒解密流程

科技的发展带动了企业生产&#xff0c;越来越多的企业开始利用计算机服务器办公&#xff0c;为企业的生产运营提供了极大便利&#xff0c;但随之而来的网络安全威胁也引起了众多企业的关注。近日&#xff0c;云天数据恢复中心接到许多企业的求助&#xff0c;企业的计算机服务器…

(每日持续更新)信息系统项目管理(第四版)(高级项目管理)考试重点整理 第13章 项目资源管理(七)

项目建议与立项申请、初步可行性研究、详细可行性研究、评估与决策是项目投资前使其的四个阶段。在实际工作中&#xff0c;初步可行性研究和详细可行性研究可以依据项目的规模和繁简程度合二为一&#xff0c;但详细可行性研究是不可缺少的。升级改造项目制作初步和详细研究&…

【01背包与完全背包】Aswing

01 https://www.acwing.com/problem/content/description/2/ #include<bits/stdc.h>using namespace std;const int MAXN 1005; int v[MAXN]; // 体积 int w[MAXN]; // 价值 int f[MAXN][MAXN]; // f[i][j], j体积下前i个物品的最大价值 int main() {int n,…