继【C】字符函数和字符串函数(上),这章主要来介绍以下库函数
- 字符串查找
strstr
strtok - 错误信息报告
strerror - 字符操作
目录
1、 strstr
strstr在一个字符串中另外一个字符串是否存在,
若存在:返回字符串的第一个出现的字符串的首地址
若不存在:返回NULL
示例:
#include <stdio.h> //strstr在一个字符串中另外一个字符串是否存在, //若存在:返回字符串的第一个出现的字符串的首地址 //若不存在:返回NULL int main() { char arr1[] = "abcdef"; char arr2[] = "bcd"; char* p = strstr(arr1, arr2); if (p == NULL) { printf("不存在"); } else { printf("%s\n", p); } return 0; }
运行结果:
int main() { char arr1[] = "abcdefabcdef"; char arr2[] = "cde"; char* p = strstr(arr1, arr2); if (p == NULL) { printf("不存在"); } else { printf("%s\n", p); } return 0; }
运行结果:
strstr库函数的模拟实现:
思路:
代码:
//strstr的模拟实现 char* my_strstr(const char* str1, const char* str2) { const char* s1 = str1; const char* s2 = str2; const char* p = str1; while (*p)//*p!='\0' { s1 = p; s2 = str2; while (*s1 != '\0' && *s2!='\0' && (*s1 == *s2)) { s1++; s2++; } if (*s2 == '\0') { return(char*)p;//找到了 } p++; } return NULL;//找不到子串 } // //KMP 算法 - B站搜索:比特大鹏哥 //难度页比较大一些 int main() { char arr1[] = "abcdefabcdef"; char arr2[] = "cde"; char* p = my_strstr(arr1, arr2); if (p == NULL) { printf("不存在"); } else { printf("%s\n", p); } return 0; }
运行结果:
2、 strtok字符切割函数
char * strtok ( char * str, const char * sep );
- sep参数是个字符串,定义了用作分隔符的字符集合
- 第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标记。
- strtok函数找到str中的下一个标记,并将其用\0结尾,返回一个指向这个标记的指针。(注:strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容并且可修改。)
- strtok函数的第一个参数不为NULL,函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置。
- strtok函数的第一个参数为NULL,函数将在同一个字符串中被保存的位置开始,查找下一个标记。
- 如果字符串中不存在更多的标记,则返回NULL指针。
示例:
//strtok库函数介绍 #include<string.h>//strcpy strtok #include<stdio.h>//null int main() { char arr[] = "ligongwei@liting.com"; //定义:char* strtok(char* str, const char* sep);sep是分割符,str是字符串整体 //要分别提取出,@ 和 .作为分割符 //ligongwei //liting //com char buf[200] = { 0 }; strcpy(buf, arr);//strtok会改变被操作的字符串,所以将数组中的内容临时拷贝给buf const char* p = "@."; char* str = strtok(buf, p);//函数第一个参数不为空,找到第一个分割符即标记(@),然后将标记改为\0进行结尾,返回指向\0前面部分(ligongwei)的指针 就是z的地址 printf("%s\n", str); str = strtok(NULL, p);//strtok函数的第一个参数为NULL,函数将在同一个字符串中被保存的位置(\0)开始,查找下一个标记(.),改为\0,返回指向前面部分(liting)的指针 就是l的地址 printf("%s\n", str); str = strtok(NULL, p);//第一个参数为空,执行类似上面的操作 printf("%s\n", str); str = strtok(NULL, p);//第一个参数为空,而后面没有了标记,则返回NULL printf("%s\n", str); }
运行结果
前面的代码过于无脑,为的是更好的理解strtok库函数,这里我们对代码进行了改进:
#include<string.h>//strcpy strtok #include<stdio.h>//null int main() { char arr[] = "ligongwei@liting.com"; char buf[200] = { 0 }; strcpy(buf, arr); const char* p = "@."; char* str = NULL; for (str = strtok(buf, p); str != NULL; str = strtok(NULL, p)) { printf("%s\n", str); } return 0; }
运行结果:
3、 strerror错误信息报告函数
返回错误码,所对应的错误信息。
char * strerror ( int errnum );
4、字符分类函数:
函数 | 如果他的参数符合下列条件就返回真 ,如果不是返回0 |
iscntrl | 任何控制字符 |
isspace | 空白字符:空格‘ ’,换页‘\f’,换行’\n’,回车‘\r’,制表符’\t’或者垂直制表符’\v’ |
isdigit | 十进制数字 0~9 |
isxdigit | 十六进制数字,包括所有十进制数字,小写字母a~f,大写字母A~F |
islower | 小写字母a~z |
isupper | 大写字母A~Z |
isalpha | 字母a~z或A~Z |
isalnum | 字母或者数字,a~z,A~Z,0~9 |
ispunct | 标点符号,任何不属于数字或者字母的图形字符(可打印) |
isgraph | 任何图形字符 |
isprint | 任何可打印字符,包括图形字符和空白字符 |
示例:
//字符分类函数 #include<ctype.h>//字符分类函数通用 #include<stdio.h> int main() { char ch = 'A'; //'0''1' '2' '3'……'9' int ret = isxdigit(ch); printf("%d\n", ret); return 0; }
其他的函数用法基本一样
需要注意的是:
如果函数参数符合条件就返回真 ,如果不是返回0
5、字符转换:
int tolower ( int c ); int toupper ( int c );
示例:
int main() { char ch = 't'; printf("%c\n", toupper(ch)); //printf("%c\n", tolower(ch)); return 0; }
输出结果:
#include<stdio.h> #include<ctype.h> int main() { char arr[] = "Are you ok?"; char* p = arr; while (*p)//*p!=\0就执行 { if (islower(*p)) { *p = toupper(*p); } p++; } printf("%s\n", arr); return 0; }
输出结果:
结语:
这里我们关于C】字符函数和字符串函数(下)的内容就介绍完了,文章中某些内容我们之前有介绍,所以只是一笔带过,还请谅解。希望以上内容对大家有所帮助👀,如有不足望指出🙏
加油!!