【C】字符函数和字符串函数(下)
🙈个人主页: 对de起日子
👉系列专栏:【C语言–大佬之路】
🎈今日心语:一个人只要有意志力,就能超越他的环境。
继【C】字符函数和字符串函数(上),这章主要来介绍以下库函数
- 字符串查找
strstr
strtok - 错误信息报告
strerror - 字符操作
目录
- 1、 strstr
- 2、 strtok字符切割函数
- 3、 strerror错误信息报告函数
- 4、字符分类函数:
- 5、字符转换:
- 结语:
1、 strstr

strstr在一个字符串中另外一个字符串是否存在,
若存在:返回字符串的第一个出现的字符串的首地址
若不存在:返回NULL
示例:
#include
//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 //strcpy strtok
#include //null
int main()
{char arr[] = "ligongwei@liting.com";//定义:char* strtok(char* str, const char* sep);sep是分割符,str是字符串整体//要分别提取出,@ 和 .作为分割符//ligongwei//liting//comchar buf[200] = { 0 };strcpy(buf, arr);//strtok会改变被操作的字符串,所以将数组中的内容临时拷贝给bufconst 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);//第一个参数为空,而后面没有了标记,则返回NULLprintf("%s\n", str);}
运行结果

前面的代码过于无脑,为的是更好的理解strtok库函数,这里我们对代码进行了改进:
#include //strcpy strtok
#include //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 //字符分类函数通用
#include
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
#include
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】字符函数和字符串函数(下)的内容就介绍完了,文章中某些内容我们之前有介绍,所以只是一笔带过,还请谅解。希望以上内容对大家有所帮助👀,如有不足望指出🙏

加油!!
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
