《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 类型

 

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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Flink概述

1.什么是Flink 是一个框架和分布式处理引擎&#xff0c;用于对无界和有界数据流进行有状态计算。 官网&#xff1a;Flink 2.Flink的发展历史 Flink起源于一个叫作Stratosphere的项目&#xff0c;它是由3所地处柏林的大学和欧洲其他一些大学在2010~2014年共同进行的研究项目&a…

从零开始:神经网络(2)——MP模型

声明&#xff1a;本文章是根据网上资料&#xff0c;加上自己整理和理解而成&#xff0c;仅为记录自己学习的点点滴滴。可能有错误&#xff0c;欢迎大家指正。 神经元相关知识&#xff0c;详见从零开始&#xff1a;神经网络——神经元和梯度下降-CSDN博客 1、什么是M-P 模型 人…

物联网云原生云边协同

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

构建高效可靠的消息队列系统:设计与实现

✨✨谢谢大家捧场&#xff0c;祝屏幕前的小伙伴们每天都有好运相伴左右&#xff0c;一定要天天开心哦&#xff01;✨✨ &#x1f388;&#x1f388;作者主页&#xff1a; 喔的嘛呀&#x1f388;&#x1f388; 目录 一、引言 二、设计目标 2.1、高可用性 1. 集群搭建 1.1 …

MACBOOK PRO M2 MAX 安装Stable Diffusion及文生图实例

以前偶尔会使用Midjourney生成一些图片&#xff0c;现在使用的头像就是当时花钱在Midjourney上生成的。前段时间从某鱼上拍了一台性价比还不错的macbook&#xff0c;想着不如自己部署Stable Diffusion&#xff08;以下简称SD&#xff09;尝试一下。 网上有很多教程&#xff0c…

数组的内存执行原理

一.Java内存分配介绍 JVM虚拟机会在内存中执行程序 java内存分配介绍 方法区&#xff0c;栈&#xff0c;堆 首先将编译过后的.class文件送入方法区中。当类开始运行时将方法调入栈内存中&#xff0c;变量也是属于方法的&#xff0c;因此同方法一起进入栈内存中。当main方法要…

日期问题---算法精讲

前言 今天讲讲日期问题&#xff0c;所谓日期问题&#xff0c;在蓝桥杯中出现众多&#xff0c;但是解法比较固定。 一般有判断日期合法性&#xff0c;判断是否闰年&#xff0c;判断日期的特殊形式&#xff08;回文或abababab型等&#xff09; 目录 例题 题2 题三 总结 …

人工智能|机器学习——K-means系列聚类算法k-means/ k-modes/ k-prototypes/ ......(划分聚类)

1.k-means聚类 1.1.算法简介 K-Means算法又称K均值算法&#xff0c;属于聚类&#xff08;clustering&#xff09;算法的一种&#xff0c;是应用最广泛的聚类算法之一。所谓聚类&#xff0c;即根据相似性原则&#xff0c;将具有较高相似度的数据对象划分至同一类簇&#xff0c;…

CentOS 7.6安装部署Seafile服务器

今天飞飞和你们分享CentOS 7.6上安装基于MySQL/MariaDB的Seafile服务器的方法&#xff0c;包括下载和安装7.0.5版本、配置数据库、启动服务器等步骤。安装成功后&#xff0c;需要通过nginx反向代理才能访问seafile服务。 通过预编译好的安装包来安装并运行基于 MySQL/MariaDB …

Day27:安全开发-PHP应用TP框架路由访问对象操作内置过滤绕过核心漏洞

目录 TP框架-开发-配置架构&路由&MVC模型 TP框架-安全-不安全写法&版本过滤绕过 思维导图 PHP知识点 功能&#xff1a;新闻列表&#xff0c;会员中心&#xff0c;资源下载&#xff0c;留言版&#xff0c;后台模块&#xff0c;模版引用&#xff0c;框架开发等 技…

网络触手获取天气数据存入mysql 项目

首先这个案例不一定能直接拿来用&#xff0c;虽然我觉得可以但是里面肯定有一些我没考虑到的地方。 有问题评论或者私信我&#xff1a; 这个案例适合我这种学生小白 获取天气数据网址&#xff1a; https://lishi.tianqi.com/xianyang/202201.html 网络触手获取天气数据代码直…

Svg Flow Editor 原生svg流程图编辑器(二)

系列文章 Svg Flow Editor 原生svg流程图编辑器&#xff08;一&#xff09; 说明 这项目也是我第一次写TS代码哈&#xff0c;现在还被绕在类型中头昏脑胀&#xff0c;更新可能会慢点&#xff0c;大家见谅~ 目前实现的功能&#xff1a;1. 元件的创建、移动、形变&#xff1b;2…

运动想象 (MI) 迁移学习系列 (3) : MSFT

运动想象迁移学习系列:MSFT 0. 引言1. 主要贡献2. 数据增强方法3. 基于度量的空间滤波转换器3.1 空间过滤3.2 脑电图ViT3.2.1 变压器编码器层3.2.2 基于度量的损失函数 4. 实验结果4.1 消融实验4.2 基线任务对比4.3 跨主题 5. 总结欢迎来稿 论文地址&#xff1a;https://www.s…

深入浅出计算机网络 day.1 概论② 因特网概述

当你回头看的时候&#xff0c;你会发现自己走了一段&#xff0c;自己都没想到的路 —— 24.3.9 内容概述 01.网络、互连&#xff08;联&#xff09;网与因特网的区别与联系 02.因特网简介 一、网络、互连&#xff08;联&#xff09;网与因特网的区别与联系 1.若干节点和链路互连…

Java 客户端向服务端上传文件(TCP通信)

一、实验内容 编写一个客户端向服务端上传文件的程序&#xff0c;要求使用TCP通信的的知识&#xff0c;完成将本地机器输入的路径下的文件上传到D盘中名称为upload的文件夹中。并把客户端的IP地址加上count标识作为上传后文件的文件名&#xff0c;即IP&#xff08;count&#…

excel统计分析——嵌套设计

参考资料&#xff1a;生物统计学&#xff0c;巢式嵌套设计的方差分析 嵌套设计&#xff08;nested design&#xff09;也称为系统分组设计或巢式设计&#xff0c;是把试验空间逐级向低层次划分的试验设计方法。与裂区设计相似&#xff0c;先按一级因素设计试验&#xff0c;然后…

Linux网络套接字之预备知识

(&#xff61;&#xff65;∀&#xff65;)&#xff89;&#xff9e;嗨&#xff01;你好这里是ky233的主页&#xff1a;这里是ky233的主页&#xff0c;欢迎光临~https://blog.csdn.net/ky233?typeblog 点个关注不迷路⌯▾⌯ 目录 一、预备知识 1.理解源IP地址和目的IP地址 …

真实案例分享:MOS管电源开关电路,遇到上电冲击电流超标

做硬件&#xff0c;堆经验。 分享一个案例&#xff1a;MOS管电源开关电路&#xff0c;遇到上电冲击电流超标&#xff0c;怎么解决的呢&#xff1f; 下面是正文部分。 —— 正文 —— 最近有一颗用了挺久的MOSFET发了停产通知&#xff0c;供应链部门找到我们研发部门&#xff0c…

RabbitMQ发布确认高级版

1.前言 在生产环境中由于一些不明原因&#xff0c;导致 RabbitMQ 重启&#xff0c;在 RabbitMQ 重启期间生产者消息投递失败&#xff0c; 导致消息丢失&#xff0c;需要手动处理和恢复。于是&#xff0c;我们开始思考&#xff0c;如何才能进行 RabbitMQ 的消息可靠投递呢&…

C++——string模拟实现

前言&#xff1a;上篇文章我们对string类及其常用的接口方法的使用进行了分享&#xff0c;这篇文章将着重进行对这些常用的接口方法的内部细节进行分享和模拟实现。 目录 一.基础框架 二.遍历字符串 1.[]运算符重载 2.迭代器 3.范围for 三.常用方法 1.增加 2.删除 3.调…