和黛玉学编程..........>
大家一起努力成为更好的自己吧
1.C语言中有一系列函数是用来做字符分类的,也就是一个字符是属于什么类型的字符的,都需要包含头文件:ctype.h
这些函数前面都有一个is,可以理解为是,后面的字符从意思就可以看出来这种函数的作用,连起来就是是xxx函数,如果符合就返回真拉
函数 | 如果符合就返回真 |
iscntrl | 任何控制字符 |
isspace | 空白字符 |
isdigit | 十进制0到9 |
isxdigit | 十六进制 |
islower | 小写字母 |
isupper | 大写字母 |
isalpha | 字母 |
isalnum | 字母或者数字 |
ispunct | 标点符号 |
isgraph | 任何图形字符 |
isprint | 任何可打印字符 |
1 . int tolower( int c ) 把传进去的大写字母变成小写
2. int toupper( int c ) 把传进去的小写字母变成大写
从to这个单词就可以看成变成的意思,上面的islower就是是不是的意思
#include
#include
int main ()
{
int i = 0;
char str[] = "Test String.\n";
char c;
while (str[i])
{
c = str[i];
if (islower(c))
c = toupper(c);
putchar(c);
i++;
}
return 0;
}
结果如下:
size_t strlen ( const char * str )
1.字符串以 '\0' 作为结束标志,strlen函数返回的是在字符串中 '\0' 前⾯出现的字符个数(不包 含 '\0' )。
#include
#include
int main()
{
char* arr = "abjdshfuks";
int ret = strlen(arr);
printf("%d\n", ret);
return 0;
}
1.我们不仅仅会用这个函数,还需要知道怎么模拟实现,下面是小编为你们提供的三种方法呀
NO.1
采用计数器的方式,计算‘\0’前面字符的个数
int my_strlen(const char * str)
{
int count = 0;
assert(str);
while(*str)
{
count++;
str++;
}
return count;
}
NO.2
采用递归的方式
int my_strlen(const char * str)
{
assert(str);
if(*str == '\0')
return 0;
else
return 1+my_strlen(str+1);
}
NO.3
采用指针-指针的方式,前面的文章我们讲过,指针-指针是计算他们之间的个数,所以我们可以先把首地址存起来
int my_strlen(char *s)
{
assert(str);
char *p = s;
while(*p != ‘\0’ )
p++;
return p-s;
}
char* strcpy(char * destination, const char * source );
从cpy我们可以联想到copy,在英文中是拷贝的意思,所以这个函数可以实现字符的拷贝,source代表的是需要拷贝的字符,destination是拷贝的位置
char *my_strcpy(char *dest, const char*src)
{
char *ret = dest;
assert(dest != NULL);
assert(src != NULL);
while((*dest++ = *src++))
{
;
}
return ret;
}
strcat函数主要是把一个字符串追加到另外一个字符串后面
char *my_strcat(char *dest, const char*src)
{
char *ret = dest;
assert(dest != NULL);
assert(src != NULL);
while(*dest)
{
dest++;
}
while((*dest++ = *src++))
{
;
}
return ret;
}
可以实现字符串的比较,注意的是比较的不是个数,cmp联想到compare的意思,也就是比较哦,这样子可以更方便理解
int my_strcmp (const char * str1, const char * str2)
{
int ret = 0 ;
assert(src != NULL);
assert(dest != NULL);
while(*str1 == *str2)
{
if(*str1 == '\0')
return 0;
str1++;
str2++;
}
return *str1-*str2;
}
char * strncpy ( char * destination, const char * source, size_t num );
这里的num表示的是你想要拷贝几个字符
这个比strcpy多了个n,可以理解为加强版的,你想拷贝几个就体现在这个num里面
char * strncat ( char * destination, const char * source, size_t num );
这个函数也可以理解为strcat加强版
将source指向字符串的前num个字符追加到destination指向的字符串末尾,再追加⼀个 \0 字 符)
#include
#include
int main ()
{
char str1[20];
char str2[20];
strcpy (str1,"To be ");
strcpy (str2,"or not to be");
strncat (str1, str2, 6);
printf("%s\n", str1);
return 0;
}
int strncmp ( const char * str1, const char * str2, size_t num );
char * strstr ( const char * str1, const char * str2);
#include
#include
int main ()
{
char str[] ="This is a simple string";
char * pch;
pch = strstr (str,"simple");
strncpy (pch,"sample",6);
printf("%s\n", str);
return 0;
}
这个代码首先先找到这个位置,然后修改这个位置的内容
char * strstr (const char * str1, const char * str2)
{
char *cp = (char *) str1;
char *s1, *s2;
if ( !*str2 )
return((char *)str1);
while (*cp)
{
s1 = cp;
s2 = (char *) str2;
while ( *s1 && *s2 && !(*s1-*s2) )
s1++, s2++;
if (!*s2)
return(cp);
cp++;
}
return(NULL);
}
char * strtok ( char * str, const char * sep);
这个函数起到分隔的作用
#include
#include
int main()
{
char arr[] = "[email protected]";
char* sep = "@.";
char* str = NULL;
for (str = strtok(arr, sep); str != NULL; str = strtok(NULL, sep))
{
printf("%s\n", str);
}
return 0;
}