【C】字符串函数——大全(简洁,精炼,初学者)
字符串函数大全与应用场景,以及字符串函数的模拟详解。适合收藏,当作大全!
前言:大家好,这里是YY;此篇博客主要是字符串函数的知识点;包含【C语言对字符和字符串的处理】【strlen】【strcpy】【stract】【strcmp】【strcpy,strcmp,strcat与strncpy,strncmp,strncat比较】【strncpy】【strncmp】【strncat】【strstr】【strtok】【strerror】【perror】【字符分类函数】【字符转化函数】
PS:创作不易,每个知识点都有例题或者图帮助理解;如果对你有帮助,希望能够得到您的关注,赞,收藏,谢谢!
目录
六.strcpy,strcmp,strcat与strncpy,strncmp,strncat比较
一.C语言对字符和字符串的处理
C语言中对字符和字符串的处理很是频繁,但是C语言本身并没有字符串类型,字符串通常放在常量字符串或者字符数组中。
PS:字符串常量适用于那些对它不做修改的字符串函数
常量字符串:
"hello my friend! \0"//默认后面会有\0
字符数组:
char arr[]="welcome to my blog! \0";//默认后面会有\0
1.字符串函数的头文件
#include<string.h>
二.strlen(字符长度函数)
特性:
- strlen的返回类型是unsigned int
- 无符号数-无符号数还是无符号数
使用场景:
1.模拟实现strlen
原理:指针-指针
注意点:const修饰的指针到另一个指针时,也应该受保护(+const)
三.strcpy(字符拷贝函数)
注意:返回类型为char*,打印时可以接受其返回值
使用场景:
1.strcpy的2种特性
一.strcpy会拷贝"\0"
如果不拷贝\0会报错(越界)
二.能越界访问,但报错
(虽然能成功拷贝,但仍然会报错)(要保证目标空间足够大·)
2.场景:拷贝放到常量字符串
前提条件:(目标指针指向的空间必须可修改)
3.模拟实现strcpy
原理:逐个改变目的地的地址,即指针(地址)覆盖
四.stract(字符追加函数)
PS:与strcpy类似,参数部分都是前目的地,后源。
使用场景:
特性:
追加字符串时,源字符串必须有\0
- 会覆盖待追加代码的\0(从第一个\0处开始追加)
1.模拟实现strcat
比模拟实现strcpy多了一步:设置cur指针,重新找拼接的头指针(覆盖掉源代码的\0)
2.(特性实例)情景1:能否实现自己追加自己?NO
分析:
- stract的特性之一就是会覆盖待追加代码的"\0"
五.strcmp(字符比较函数)
注意点:
比较对应位置上字符的Ascall值的大小
一定要有‘\0’,即终止符号
与字符串的长短无关 !!!!!!!!!!!!
使用场景:
1.模拟实现strcmp
原理:逐字符比较
六.strcpy,strcmp,strcat与strncpy,strncmp,strncat比较
直观区别:
- 长度受限制的字符串函数
- 长度不受限制的字符串函数
PS:strncpy,strncat不仅是长度受限与否的区别,还有特性上的区别
七.strncpy
应用场景:
一:情景:strncpy遇到过分拷贝时的运作
strncpy特性:不够拷贝的部分,补上" \0"
八.strncmp
运用场景:
九.strncat
PS:与strcmp对比,解决了无法自己追加自己的问题
特性:
- strncat追加的字符串后面还是有\0
- 追加的个数n,不包含\0
一:情景: "自己追加自己"可行
原理:
strncat追加的字符串后面还是有\0,---解决了\0被覆盖从而无法读取的情况
运用场景:
十.strstr(在一个字符串中查找另一个字符串是否存在)
返回值的情况:
- 存在:返回子串第一次出现的位置
- 不存在: 返回NULL
使用场景:
1.模拟实现strstr
原理:分别设置两个比对指针s1,s2,设置一个指针p记录开始匹配的位置
代码实现:
十一.strtok(字符串分解为数组字符串)
PS: str 为待分解字符串,delim 为分隔符(也为字符串)
综述:
返回值:
- 该函数返回被分解的第一个子字符串
- 如果没有可检索的字符串,则返回一个空指针(str!NULL即可控制循环)
使用要点:
- 存储分割符的字符串p,分割一次后会自动跳到下一个字符
- strtok有记忆功能,会记住他改变的地址
- 第一次如果传回非空,则第二次一定要传回NULL!!!!!!!!!!!!!
(第一次传入非空,将会从str中找到第一个分隔符处的位置,并记忆;第二次传入NULL,是为了确保函数从第一次操作中记忆的位置再次开始运行,寻找下一个标记)
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<ctype.h> #include<string.h> int main() { char arr[] = "yy@qq.com"; char buf[200] = { 0 }; strcpy(buf, arr); const char* p = "@."; char* str = NULL; //第一次传入buf为非空,则接下来在此循环一定要传入NULL for (str = strtok(buf, p); str != NULL; str = strtok(NULL, p)) { printf("%s\n", str); } return 0; } 输出结果: yy qq com
十二.strerror(翻译错误码)
错误码:0,1,2,3,4(C语言中库函数报错时的错误码)
功能:接收错误码并把错误码转换成错误信息
PS:errno是c语言提供的全局的错误变量,当调用时,错误码就会存进去
应用场景:
十三.perror(显示函数错误原因)
要点:
相当于printf与strerror的结合
可以加入自定义内容
使用场景:
十四.字符分类函数
1.字符分类函数的头文件
#include<ctype.h>
2.字符分类函数总览
一.演示用例:isdigit函数(判断是否为数字字符)
返回值:非数字字符返回0;数字字符返回非0;
使用场景:
十五.字符转化函数(大小写英文字符转换)
1.字符转化函数的头文件
#include<ctype.h>
2.字符转化函数总览
返回值:
- toupper;返回转换后的大写字母,若不须转换则将参数c值返回。
- tolower;返回转换后的小写字母,若不须转换则将参数c值返回。
运用场景:
一: 运用场景:把字符串中的小写转成大写
int main() { char arr[] = "Hello"; char* p = arr; while (*p++) { //把所有字符先变成小写,再变成大写 if (islower(*p)) { *p = toupper(*p); } } printf("%s", arr); return 0; }
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)