C,C++中常用的操作字符串的函数
- 更新时间:2022-10-10 09:27:12
- 编辑:韶宏恺
小小的做一个总结
函数名: stpcpy
功 能: 拷贝一个字符串到另一个,遇到'\0'时停止拷贝,destin要有足够大的空间
用 法: char *stpcpy(char *destin, char *source);
函数名: strcat
功 能: 字符串拼接函数,注意,destin要有足够大的空间
用 法: char *strcat(char *destin, char *source);
函数名: strchr
功 能: 在一个串中查找给定字符的第一个匹配之处,找不到返回NULL
用 法: char *strchr(char *str, char c);
函数名: strcmp
功 能: 字符串大小比较,str1>str2 返回1,str1<str2 返回-1,相等返回0
用 法: int strcmp(char *str1, char *str2);
函数名: strncmpi
功 能: 比较字符串str1和str2的前maxlen个字符,忽略大小写
用 法: int strncmpi(char *str1, char *str2, unsigned maxlen);
函数名: strcpy
功 能: 遇到'\0'时停止拷贝,destin要有足够大的空间
用 法: char *strcpy(char *str1, char *str2);
函数名: strcspn
功 能: 返回字符串s1中第一个在s2中出现的字符在s1中的下标值,亦即在s1中出现而s2中没有出现的子串的长度
用 法: int strcspn(char *str1, char *str2);
程序例:
str1="Golden Global View"; str2 = "new"
在s1中,且在s2中, n e w这三个字符都满足,而e是在s1中最先出现的,所以返回它的位置
函数名: strdup
功 能: 将串拷贝到新建的位置处,注意,在使用该函数时,申请了一片新的内存,所以使用后必须释放
用 法: char *strdup(char *str);
程序例:
#include <stdio.h> #include <string.h> #include <alloc.h> int main(void) { char *dup_str, *string = "abcde"; dup_str = strdup(string); // 申请了一片新的内存地址,dup_str指向了这片内存 printf("%s\n", dup_str); free(dup_str); // 一定要释放 return 0; }
函数名: stricmp
功 能: 比较字符串大小,忽略大小写
用 法: int stricmp(char *str1, char *str2);
函数名: strerror
功 能: 返回指向错误信息字符串的指针
用 法: char *strerror(int errnum);
程序例:
#include <stdio.h> #include <errno.h> int main(void) { char *buffer; buffer = strerror(errno); printf("Error: %s\n", buffer); return 0; }
函数名: strcmpi
功 能: 比较两个字符串,忽略大小写
用 法: int strcmpi(char *str1, char *str2);
函数名: strncmp
功 能: 比较字符串大小 maxlen是比较的位数
用 法: int strncmp(char *str1, char *str2, int maxlen);
函数名: strncmpi
功 能: 把串中的一部分与另一串中的一部分比较, 不管大小写,maxlen是比较的位数
用 法: int strncmpi(char *str1, char *str2,int maxlen);
函数名: strncpy
功 能: 串拷贝 maxlen规定拷多少位
用 法: char *strncpy(char *destin, char *source, int maxlen);
函数名: strnicmp
功 能: 忽略大小写比较字符串 maxlen是比较的位数
用 法: int strnicmp(char *str1, char *str2, unsigned maxlen);
函数名: strnset
功 能: 将一个字符串中的前n个字符都设为指定字符ch
用 法: char *strnset(char *str, char ch, unsigned n);
函数名: strpbrk
功 能: 在源字符串(s1)中找出最先含有搜索字符串(s2)中任一字符的位置并返回,若找不到则返回空指针
用 法: char *strpbrk(char *str1, char *str2);
函数名: strrchr
功 能: 在串中查找指定字符的最后一个出现
用 法: char *strrchr(char *str, char c);
函数名: strrev
功 能: 串倒转
用 法: char *strrev(char *str);
函数名: strset
功 能: 将一个串中的所有字符都设为指定字符
用 法: char *strset(char *str, char c);
函数名: strspn
功 能: 返回字符串str1中第一个不在指定字符串str2中出现的字符下标
用 法: int strspn(char *str1, char *str2);
函数名: strstr
功 能: 在串中查找指定字符串的第一次出现
用 法: char *strstr(char *str1, char *str2);
函数名: strtok
功 能: 查找由在第二个串中指定的分界符分隔开的单词
用 法: char *strtok(char *str1, char *str2);
程序例:
#include<iostream> #include<cstring> using namespace std; int main() { char sentence[]="This is a sentence with 7 tokens"; cout<< "The string to be tokenized is:\n"<< sentence <<"\n\nThe tokens are:\n\n"; char *tokenPtr=strtok(sentence," "); while(tokenPtr!=NULL) { cout<<tokenPtr<<endl; tokenPtr=strtok(NULL," "); // 再次调用时,第一个参数传NULL } }
函数名: strupr
功 能: 将串中的小写字母转换为大写字母
用 法: char *strupr(char *str);
函数名: swab
功 能: 交换字节 ,nbytes是交换的字节数
用 法: void swab (char *from, char *to, int nbytes);
程序例:
#include <stdlib.h> #include <stdio.h> #include <string.h> char source[15] = "Frank Borland"; char target[15]; int main(void) { swab(source, target, strlen(source)); printf("This is target: %s\n", target); return 0; }
到此就结束了,大家可以查看下面的几篇文章。
相关教程
-
C++多文件变量解析
大家注意不要在头文件中定义变量,在头文件中声明变量。定义放在对应的源文件中。其他地方只能用extern声明
发布时间:2022-04-14
-
C++和Java命令行绘制心形图代码分享
这篇文章主要为大家详细介绍了C++和Java命令行绘制心形图案,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
发布时间:2020-04-21
-
C++实现优酷土豆去视频广告的方法
给网友们整理关于C++的教程,这篇文章主要介绍了C++实现优酷土豆去视频广告的方法,实例分析了C++实现屏蔽功能的相关技巧,需要的朋友可以参考下
发布时间:2022-09-06
-
C++实现教师管理系统
这篇文章主要为大家详细介绍了C++实现教师管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
发布时间:2022-04-16
-
C/C++实现双路快速排序算法原理
这篇文章主要为大家详细介绍了C/C++实现双路快速排序算法原理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
发布时间:2022-04-03
-
如何理解C++ 临时变量的常量性
这篇文章主要介绍了如何理解C++ 临时变量的常量性,帮助大家更好的理解和学习c++ 变量,感兴趣的朋友可以了解下
发布时间:2022-04-02
-
c++读取数据文件到数组的实例
今天小编就为大家分享一篇c++读取数据文件到数组的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
发布时间:2021-05-11
-
C++输出上三角/下三角/菱形/杨辉三角形(实现代码)
给网友朋友们带来一篇关于C++的教程,本篇文章是对C++中输出上三角/下三角/菱形/杨辉三角形的示例代码进行了详细的分析介绍,需要的朋友参考下
发布时间:2022-09-23