这章主要来介绍以下库函数
- 字符串查找 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】字符函数和字符串函数(下)的内容就介绍完了,文章中某些内容我们之前有介绍,所以只是一笔带过,还请谅解。希望以上内容对大家有所帮助👀,如有不足望指出🙏
加油!!