字符串及其函数

字符串及其函数速览

  • 字符串及其函数
    • 1. 字符串的输入输出
      • 1.1 gets()
      • 1.2 fgets()
      • 1.3 puts()
      • 1.4 fputs()
      • 1.5 sprintf()
      • 1.6 sscanf()
      • 输入输出函数案例
    • 2. 字符串相关函数速览
      • 2.1 字符串赋值
        • strset()
        • strnset()
        • strcpy()
        • strncpy()
        • strdup()
        • 下面的mem系列函数不仅能作用于字符,也能作用于其他类型
        • memset()
        • memcpy()
      • 2.3 字符串拼接
        • strcat()
        • strncat()
      • 2.4 字符串比较
        • strcmp()
        • stricmp()
        • strncmp()
      • 2.5 字符串查找
        • strchr()
        • strrchr()
        • strcspn()
        • strspn()
        • strpbrk()
        • strstr()
        • strtok()
      • 2.6 其他
        • strlen()
        • strerror()

字符串及其函数

  c语言 没有字符串类型,所以大多用字符数组代替。

1. 字符串的输入输出

使用 scanf 和 printf 的通用输入输出。

#include <stdio.h>
#include <stdlib.h>/* run this program using the console pauser or add your own getch, system("pause") or input loop */int main(int argc, char *argv[]) {//1.字符串输入char instr1[20];scanf("%s ",instr1);printf("instr1 is:%s\n",instr1);//2.字符串输入char instr2[20];gets(instr2);printf("instr2 is:%s\n",instr2);//2.字符串输出//使用字符指针定义一个字符串char * str="nihao";printf("str[2] is:%c\n",str[2]);//如果要使用字符数组表示一个字符串,那么需要添加一个 '\0' 作为结尾 char str1[10] = { 't', 'o', 'm', '\0', '7' };printf("str1 is:%s\n",str1);char * str2="jerry";printf("str2 is:%s\n",str2);char str3[]={'j','a','c','k','\0'};printf("str3 is:%s\n",str3);char str4[10]={'l','i','l','y'};printf("str4 is:%s\n",str4);return 0;
}
//输入
nihao hello world
//输出
instr1 is:nihao
instr2 is:hello world
str[2] is:h
str1 is:tom
str2 is:jerry
str3 is:jack
str4 is:lily

**注意:**这里 scanf("%s ",instr1); 与 gets(instr2); 的区别是,gets输入时可以有空格,scanf不行。

1.1 gets()

#include <stdio.h>
//s:字符串首地址
char * gets(char* s);
//成功:返回读入的字符串
//失败:返回NULL

1.2 fgets()

#include <stdio.h>
//s:字符串首地址
//size:指定最大读取字符串的长度(size - 1)
//stream:文件指针,如果读键盘输入的字符串,固定写为stdin
char *fgets(char *s, int size, FILE *stream);
//成功:返回读入的字符串
//失败:返回NULL

1.3 puts()

在输出完成后自动输出一个换行

#include <stdio.h>
//s:字符串首地址
int puts(const char *s);
//成功:返回非负数
//失败:返回-1

1.4 fputs()

#include <stdio.h>
//str:字符串
//stream:文件指针,如果把字符串输出到屏幕,固定写为stdout
int fputs(const char * str, FILE * stream);
//成功:0
//失败:-1

1.5 sprintf()

#include<stdio.h>
//arg 利用 format 格式化后输出到 des 里面
int sprintf(char *des,const char *format ,[argument,...]);//案例
char name[]="name";
char value[]="lisi";
char des[100];
int len=sprintf(des,"%s:%s",name,value);
puts(des);//输出
name:lisi

1.6 sscanf()

#include<stdio.h>
//src 利用 format 格式化 获取args参数
int sscanf(const char * src,const char * format,[argument,...]);//案例
char name[10];
char value[10];
char src[]="name = lisi";
int len=sscanf(src,"%s = %s",name,value);
printf("%s %s\n",name,value);//输出
name lisi

输入输出函数案例

//案例一  puts 和 gets 使用
#include <stdio.h>
#include <string.h>
#include <errno.h>int main(int argc, char *argv[]) {char str[50];if(NULL==gets(str)){strerror(errno);}puts(str);puts("end");return 0;
}
//输入
nihao
//输出
nihao
end//案例二 fgets 和 fputs
char str[50];
fgets(str,sizeof(str),stdin);
fputs(str,stdout);
//输入
nihao
//输出
nihao//案例三 sscanf 和 sprintf
char name[10];
char value[10];
char src[]="name = lisi";
char des[50];
int slen=sscanf(src,"%s = %s",name,value);
int plen=sprintf(des,"%s : %s",name,value);
puts(des);
//输出
name : lisi

2. 字符串相关函数速览

2.1 字符串赋值

strset()

将一个串中的所有字符都设为指定字符

#include <string.h>
//将字符串str所有字符赋值为c,前提是str有字符。
char *strset(char *str, char c);//案例
char string[10] = "1234";
char symbol = 'c';
strset(string, symbol);
printf("%s\n", string);//输出
cccc
strnset()
#include <string.h>
//将字符串str前n个字符赋值为c,前提是str有字符。
char *strnset(char *str, char c, unsigned n);//案例
char string[10] = "1234";
char symbol = 'c';
strnset(string, symbol,2);
printf("%s\n", string);
//输出
cc34
strcpy()

拷贝字符串

#include <string.h>
//把src所指由NUL结束的字符串复制到des所指的数组中
char *strcpy(char *des,char *src);
//返回:dest所指数组//案例:
char str[50];
char des[50];
gets(str);
strcpy(des,str);
puts(des);
//输入
nihao
//输出
nihao
strncpy()

拷贝部分字符串

#include <string.h>
//把src 的前n个字符拷贝到des里面
char *strncpy(char *des, char *src, int n);//案例
char src[50];
char des[50];
gets(src);
gets(des);
printf("des is:%s\n",strncpy(des,src,2));//输入
hello
world
//输出
des is:herld
strdup()

将源字符串拷贝到其他位置,并返回该位置的字符指针值。

#include <string.h>
//拷贝字符串str,返回值赋值给字符指针变量
char *strdup(char *str);//案例
char str[10]="123hello";
char * des;
des=strdup(str);
str[2]='k';
puts(des);
puts(str);//输出
123hello
12khello
下面的mem系列函数不仅能作用于字符,也能作用于其他类型
memset()
#include <string.h>
//给str位置处后面n个字节赋值为ch并返回str
void *memset(void *str, int ch, size_t n);//通常用于初始化数组
int arr[10];
memset(arr,0,sizeof(arr));
printf("%d\n",arr[0]);
memcpy()

拷贝src几个元素到前面des中

#include <string.h>
//拷贝几个字符到des
void *memcpy(void * des,const void * src,size_t n);

2.3 字符串拼接

strcat()

拼接字符串

#include <string.h>
//把src拼接到des后面
char *strcat(char *des,char *src);//案例:
char str[50];
char des[50];
gets(des);
gets(str);
strcat(des,str);
puts(des);//输入
hello 
world
//输出
hello world
strncat()

拼接部分字符串

#include <string.h>
//把src的前n个字符拷贝到des后面
char *strncat(char *des,char *src,int n);//案例
char src[50];
char des[50];
gets(src);
gets(des);
printf("des is:%s\n",strncat(des,src,2));//输入
hello
world
//输出
des is:worldhe

2.4 字符串比较

strcmp()

两个字符串进行比较ASCII码大小

#include <string.h>
//str1 和 str2 比较,str1大返回1 ,小返回-1
int strcmp(char *str1, char *str2);//案例
char str[10]="123hello";
char * des="234world";
printf("res is:%d\n",strcmp(str,des));//输出
res is:-1
stricmp()

两个字符串进行比较ASCII码大小,不区分大小写,使用方式和上面一样。

strncmp()

比较前几个字符串

int strncmp(char *str1, char *str2,int maxlen);

2.5 字符串查找

strchr()

从左到右在str中查找第一个c的位置,返回这个位置字符的指针

#include <string.h>
//从左到右在str中查找c的位置,返回这个位置字符的指针
char *strchr(const char *str, int c);//案例
char str[10] = "12c34";
char symbol = 'c';
char* pos=strchr(str, symbol);
printf("%d\n", pos-str);
//输出
2
strrchr()

从右往左在str中查找第一个c的位置,返回这个位置字符的指针,用法同上。

strcspn()

  该函数名是 string complementary span 的缩写,函数作用是将str2里面的字符串中所有的字符去str1中查找,然后统计这些查找到的位置,返回位置最靠前的位置。至少能找到 ‘/0’ 字符串结尾字符,此时输出的是 str1 的字符串长度。

#include <string.h>
//返回字符串str1中第一个在指定字符串str2中出现的字符下标
int strcspn(char *str1, char *str2);//案例
char * src1="123hello";
char * src2="45nihlo";
printf("pos is:%d\n",strcspn(src1,src2));
//输出
pos is:3
strspn()
#include <string.h>
//返回字符串str1中第一个不在指定字符串str2中出现的字符下标
int strspn(char *str1, char *str2);//案例
char * src1="123hello";
char * src2="123nihao";
printf("pos is:%d\n",strspn(src1,src2));//输出
pos is:4
strpbrk()

这个作用类似strcspn()区别是strpbrk这个返回的是位置指针,strcspn返回的是位置坐标。

#include <string.h>
char *strpbrk(char *str1, char *str2);//案例
char *str1 = "123hello";
char *str2 = "nihao";
printf("pos is:%d\n",strpbrk(str1, str2)-str1);//输出
pos is:3
strstr()

查找子串

#include <string.h>
//查找str2在str1中的位置,如果没有返回
char *strstr(char *str1, char *str2);//案例
char *str1 = "123hello";
char *str2 = "ell";
printf("pos is:%d\n",strstr(str1, str2)-str1);//输出
pos is:4
strtok()

可以理解成string token,返回str中被token分隔的串

#include <string.h>
//查找str1中被str2符号分隔的单词,注意下面的str2可以是一个字符或者一个字符串
char *strtok(char *str1, char *str2);//案例
char input[16] = "abc,d,e,f";
char *p;
//查找分隔符的第一个单词 
p = strtok(input, ",");
if (p) printf("str is: %s\n", p);
//第二次使用NULL作为第一个参数,可以输出后续的分隔单词 
while(p = strtok(NULL, ",")){printf("next seq word is %s\n", p);
}
//输出
str is: abc
next seq word is d
next seq word is e
next seq word is f

2.6 其他

strlen()

查看 str 的长度

char str[50];
gets(str);
strlen(str);
puts(str);//输入
nihao
//输出
strlen is:5
strerror()
#include <string.h>
//返回错误字符串的指针
char *strerror(int errnum);//案例
#include <stdio.h>
#include <string.h>
#include <errno.h>
int main()
{FILE *fp = NULL;fp = fopen("./test.txt", "r");if (NULL == fp) {fprintf(stderr, "error info: %s\n", strerror(errno));exit(-1);}return 0;
}//输出
error info: No such file or directory

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

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

相关文章

Windows server 2022域控制服务器的配置

Windows server 2022介绍 一、核心特性与改进 安全核心服务器&#xff08;Secured-Core Server&#xff09; 硬件级安全&#xff1a;支持基于硬件的安全功能&#xff08;如TPM 2.0、Secure Boot、基于虚拟化的安全防护VBS&#xff09;&#xff0c;防止固件攻击。受信任的启动链…

C++语法之模板函数和模板类

模板函数是什么&#xff1f;就是不指定类型的函数&#xff0c;不指定类型如何写代码?所以得用到模板&#xff0c;可以先用模板代替&#xff0c;就好像方程式&#xff0c;先用x,y代替一样。 它的写法是这样&#xff0c;定义函数时&#xff0c;开头加一句:(其中的T就相当于x,y之…

时序分析笔记

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 前言 一、周期约束 二、建立时间和保持时间 三、时序路径 四、时序模型 前言 约束文件笔记&#xff0c;傅里叶的猫的视频。 一、周期约束 时序约束就是告诉软件输…

六十天前端强化训练之第二十八天之Composition 函数完全指南

欢迎来到编程星辰海的博客讲解 看完可以给一个免费的三连吗&#xff0c;谢谢大佬&#xff01; 目录 一、核心概念解析 1.1 什么是 Composition 函数 1.2 为什么需要封装 1.3 设计原则 二、实战案例&#xff1a;鼠标跟踪器 2.1 未封装版本 2.2 封装后的 Composition 函数…

MySQL 锁机制详解

MySQL 锁机制详解 5.1 概述 锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中&#xff0c;除传统的计算资源&#xff08;CPU、 RAM、I/O&#xff09;的争用以外&#xff0c;数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、有 效性是所有数…

常见中间件漏洞攻略-Apache篇

漏洞名称&#xff1a;Apache HTTP Server 路径穿越漏洞-CVE-2021-41773 第一步&#xff1a;拉取环境、启动环境 #拉取环境 docker pull blueteamsteve/cve-2021-41773:no-cgidhttp://121.40.229.129:8080#启动环境 docker run -dit -p 8080:80 blueteamsteve/cve-2021-41773:n…

站群服务器是什么意思呢?

站群服务器是一种专门为托管和管理多个网站而设计的服务器&#xff0c;其核心特点是为每个网站分配独立的IP地址。这种服务器通常用于SEO优化、提高网站权重和排名&#xff0c;以及集中管理多个网站的需求。以下是站群服务器的详细解释&#xff1a; 一、站群服务器的定义 站群…

Excel 小黑第22套

对应大猫22 新建一行&#xff0c;输入第一个人名字&#xff0c; 填充 -快速填充 修改员工编号&#xff08;1—001&#xff09;&#xff1a;选中所有员工编号&#xff0c;开始 -数据组 -自定义数字格式 000 在所有空表格单元格中输入数字0&#xff1a;选中修改的表格范围&#…

多传感器融合 SLAM LVI-SAM

目录 LVI-SAM 简介 A. 系统概述 B. 视觉惯导系统 C.雷达惯导系统 LVI-SAM 安装编译 编译 LVI-SAM 常见问题 LVI-SAM 工程化建议 LVI-SAM 简介 源码地址:https://github.com/TixiaoShan/LVI-SAM 如无法下载,换用 gitee 版本:https://gitee.com/inf_lee/LVI-SAM 改进…

Linux shell脚本3-if语句、case语句、for语句、while语句、until语句、break语句、continue语句,格式说明及程序验证

目录 1.if 控制语句 1.1 if 语句格式 1.2 程序验证 2.case语句 2.1case语句格式 2.2程序验证 2.2.1 终端先执行程序&#xff0c;在输入一个数 2.2.2 终端执行程序时同时输入一个预设变量 2.2.3 case带有按位或运算和通配符匹配 3.for语句 3.1for语句格式 3.2程序验…

图解模糊推理过程(超详细步骤)

我们前面已经讨论了三角形、梯形、高斯型、S型、Z型、Π型6种隶属函数&#xff0c;下一步进入模糊推理阶段。 有关六种隶属函数的特点在“Pi型隶属函数&#xff08;Π-shaped Membership Function&#xff09;的详细介绍及python示例”都有详细讲解&#xff1a;https://lzm07.b…

001-JMeter的安装与配置

1.前期准备 下载好JMeter : https://jmeter.apache.org/download_jmeter.cgi 下载好JDK : :Java Downloads | Oracle 中国 下载图中圈蓝的JMeter和JDK就行&#xff0c;让它边下载&#xff0c;我们边往下看 2.为什么要下载并安装JDK ? JMeter 是基于 Java 开发的工具&#…

英伟达有哪些支持AI绘画的 工程

英伟达在AI绘画领域布局广泛&#xff0c;其自研工具与第三方合作项目共同构建了完整的技术生态。以下是其核心支持AI绘画的工程及合作项目的详细介绍&#xff1a; 一、英伟达自研AI绘画工具 1. GauGAN系列 技术特点&#xff1a;基于生成对抗网络&#xff08;GAN&#xff09;&…

Netty源码—4.客户端接入流程二

大纲 1.关于Netty客户端连接接入问题整理 2.Reactor线程模型和服务端启动流程 3.Netty新连接接入的整体处理逻辑 4.新连接接入之检测新连接 5.新连接接入之创建NioSocketChannel 6.新连接接入之绑定NioEventLoop线程 7.新连接接入之注册Selector和注册读事件 8.注册Rea…

2025.3.17-2025.3.23学习周报

目录 摘要Abstract1 文献阅读1.1 动态图邻接矩阵1.2 总体框架1.2.1 GCAM1.2.2 输出块 1.3 实验分析 总结 摘要 在本周阅读的文献中&#xff0c;作者提出了一种名为TFM-GCAM的模型。TFM-GCAM模型的创新主要分为两部分&#xff0c;一部分是交通流量矩阵的设计&#xff0c;TFM-GC…

生活电子类常识——搭建openMauns工作流+搭建易犯错解析

前言 小白一句话生成一个网站&#xff1f;小白一句话生成一个游戏&#xff1f;小白一句话生成一个ppt?小白一句话生成一个视频&#xff1f; 可以 原理 总体的执行流程是 1&#xff0c;用户下达指令 2&#xff0c;大模型根据用户指令&#xff0c;分解指令任务为多个细分步骤…

深入解析 Uniswap:自动做市商模型的数学推导与智能合约架构

目录 1. 自动做市商&#xff08;AMM&#xff09;模型的数学推导1.1 恒定乘积公式推导1.2 价格影响与滑点 2. Uniswap 智能合约架构解析2.1 核心合约&#xff08;Core&#xff09;2.1.1 工厂合约&#xff08;Factory&#xff09;2.1.2 交易对合约&#xff08;Pair&#xff09; 2…

高频面试题(含笔试高频算法整理)基本总结回顾20

干货分享&#xff0c;感谢您的阅读&#xff01; &#xff08;暂存篇---后续会删除&#xff0c;完整版和持续更新见高频面试题基本总结回顾&#xff08;含笔试高频算法整理&#xff09;&#xff09; 备注&#xff1a;引用请标注出处&#xff0c;同时存在的问题请在相关博客留言…

生成模型速通(Diffusion,VAE,GAN)

基本概念 参考视频https://www.bilibili.com/video/BV1re4y1m7gb/?spm_id_from333.337.search-card.all.click&vd_sourcef04f16dd6fd058b8328c67a3e064abd5 生成模型其实是主要是依赖概率分布&#xff0c;对输入特征的概率密度函数建模 隐空间&#xff08;latent space)…

Android在kts中简单使用AIDL

Android在kts中简单使用AIDL AIDL相信做Android都有所了解&#xff0c;跨进程通信会经常使用&#xff0c;这里就不展开讲解原理跨进程通信的方式了&#xff0c;最近项目换成kts的方式&#xff0c;于是把aidl也换成了统一的方式&#xff0c;其中遇到了很多问题&#xff0c;这里…