? ? ? ? C语言中专门分类字符的函数,需要头文件ctype.h
函数 | 符合条件返真 |
---|---|
iscntrl | 任何控制字符 |
isspace | 空白字符 空格' ' 换页\f 换行\n 回车 \r 制表符\t 垂直制表符\v |
isdigit | 十进制数字 |
isxdigit | 十六进制数字 |
islower | 小写字母 |
isupper | 大写字母 |
isalpha | 字母 |
isalnum | 字母或者数字 |
ispunct | 标点符号 |
isgraph | 任何图形字符 |
isprint | 任何可打印字符 |
????????这些函数的使用方法类似且简单
islower('b');
? ? ? ? 例子:利用函数转换小写为大写
int main()
{
char arr[] = "I am a student";
int i = 0;
while (arr[i] != '\0')
{
if (islower(arr[i]))
{
arr[i] -= 'a' - 'A';
}
i++;
}
printf("%s", arr);
}
? ? ? ? C语言仅提供了两个字符串转换函数:
int tolower (int c); //将参数传进去的大写字母转小写 int toupper (int c);?//将参数传进去的小写字母转大写
? ? ? ? 因此代码可以这样写
int main()
{
char arr[] = "I am a student";
int i = 0;
while (arr[i] != '\0')
{
arr[i] = toupper(arr[i]);
i++;
}
printf("%s", arr);
}
? ? ? ? ?size_t strlen(const char * str);
? ? ? ? ?字符串要以\0作为结束标志
? ? ? ? 参数主席昂的字符串必须要以\0结束
? ? ? ? 注意函数的返回值是size_t 是无符号
? ? ? ? strlen需要包含头文件
? ? 模拟实现
size_t my_strlen(const char* s)
{
if (*s == '\0')
{
return 0;
}
else
{
return 1 + my_strlen(++s);
}
}
int main()
{
char arr[] = "fllart";
size_t c = my_strlen(arr);
printf("%zu", c);
return 0;
}
?????????char * strcpy(char * destination,const char * source);//目标 与 源
? ? ? ? 源字符串必须以\0结束
会将源字符串中的\0拷贝到目标空间
? ? ? ? 目标空间必须足够大,以确保能存放源字符串
? ? ? ? 目标空间必须可修改
? ??????模拟实现的例子?
????????????????????????????????strcpy strcat strcmp 和 strncpy strncat strncmp
? ? ? ? ? ? ? ? strcpy 是 string?copy 拷贝字符串的意思
int main()
{
char arr[] = "hello";
char arr2[10];
strcpy(arr2, arr);
printf("%s", arr2);
}
?模拟实现
char* my_strcpy(char* destination, const char* source)
{
assert(source != NULL);
assert(destination != NULL);
char* ret = destination;
while (*destination++ = *source++);
return ret;
}
int main()
{
char arr[] = "hello coconut";
char arr2[50];
my_strcpy(arr2, arr);
printf("%s", arr2);
return 0;
}
char* strcat (char* destination, const char * source);
? ? ? ? 源字符串必须以 \0 结束
? ? ? ? 目标字符串也要有\0,否则无法知道从哪里开始
? ? ? ? 目标空间必须足够大,能容下源字符串的内容
? ? ? ? 目标空间必须可修改
? ? ? ? 让字符串自己给自己追加
? ? ? ? ? ? ? ? ?strcat是用来连接或者追加字符串的\
int main()
{
char arra[20] = "hello ";
char arrb[20] = "word";
strcat(arra, arrb);
printf("%s", arra);
return 0;
}
? ? ? ? 模拟实现
char* my_strcat(char* destination, const char* source)
{
assert(source != NULL);
assert(destination != NULL);
char* ret = destination;
while (*destination != '\0')
destination++;
while (*destination++ = *source++);
return ret;
}
int main()
{
char arra[20] = "hello ";
char arrb[20] = "word";
my_strcat(arra, arrb);
printf("%s", arra);
return 0;
}
? ? ? ? 第一个字符串大于第二个,返回大于0数字
? ? ? ? 第一个字符串等于第二个,返回0
? ? ? ? 第一个字符串小于第二个,返回小于0的值
? ? ? ? ? ? ? ? 本质上可以认为是字符串对应位的ASCLL码值的比较
int strcmp (const char * str1,const char * str2)
? ? ? ? ?例如
int main()
{
char arr1[] = "gadw";
char arr2[] = "abcdef";
int cmp = strcmp(arr1, arr2);
printf("%zu", cmp);
return 0;
}
? ? ? ? ?模拟实现
int my_strcmp(const char* str1, const char* str2)
{
while (*str1 == *str2)
{
if (*str1 == 0 && *str2 == 0)
{
return 0;
}
str1++;
str2++;
}
return *str1 - *str2;
}
int main()
{
char arr1[] = "gadw";
char arr2[] = "abcdef";
int cmp = my_strcmp(arr1, arr2);
printf("%d", cmp);
return 0;
}
? ? ? ? 长度受限制的字符串函数
? ? ? ? ? ? ? ? ? ?copy 不会补 \0 但是 cat 会补\0?
? ? ? ? ? ? ? ? ? ?相比于普通的,只有限定字符少于源字符串长度才会限制,如果超过了和普通的没有区别
char* strstr ( const char * str1,const char * str2);
? ? ? ? 函数返回字符串str2在字符串str1中第一次出现的位置
? ? ? ? 若没有就返回空指针
int main()
{
char arr1[] = "223 123 456";
char arr2[] = "123";
char* ret = strstr(arr1, arr2);
printf("%s", ret);
return 0;
}
? ? ? ? 模拟实现
char* my_strstr(const char* str1, const char* str2)//暴力查找法
{
const char* s1 = NULL;
const char* s2 = NULL;
const char* cp = str1;//当前位置开始匹配 的 "位置"
if (*str2 == '\0')
{
return (char*)str1;
}
while (*cp)
{
s1 = cp;
s2 = str2;
while (*s1!= '\0' && *s2 != '\0' && * s1 == *s2)
{
s1++;
s2++;
}
if (*s2 == '\0')
{
return cp;
}
cp++;
}
return NULL;
}
char* strtok ( char * str,const char * sep);
? ? ? ? sep参数指向了一个字符串,定义了用作分隔符的字符集合
? ? ? ? 第一个参数之地那个一个字符串,它包含了0个或者多个由sep字符串中的一个或多个分隔符分割的标记
? ? ? ? ?strtok函数找到str中的下一个标记,并将其用\0结尾,返回一个只想找个标记的指针
? ? ? ? strtok函数的第一个参数不为NULL,函数将找到str中第一个标记,strtok函数保存它在字符串中的位置.
? ? ? ? strtok函数的第一个参数为NULL,函数将在同一个字符串中被保存的位置开始,查找下一个标记
? ? ? ? 如果字符串中不存在更多的标记,则返回NULL指针
int main()
{
char arr[1000] = "12323@213123.com.awdawd@adwadwa.@awerwa..@qawewa";
char arr2[3000] = { 0 };
strcpy(arr2, arr);
const char* sep = "@.";
int* ret = NULL;
for (ret = strtok(arr2, sep); ret != NULL; ret = strtok(NULL, sep))
printf("%s\n", ret);
//ret = strtok(arr2, sep);
//printf("%s\n", ret);
//ret = strtok(NULL, sep);
//printf("%s\n", ret);
//ret = strtok(NULL, sep);
//printf("%s\n", ret);
return 0;
}
char * strerror(int errnum);
? ? ? ? ? ? ? ? 用以把参数部分错误码对应的字符串的地址返回来