• C语言学习系列-->字符函数和字符串函数


    在这里插入图片描述

    一、字符函数

    1、字符分类函数

    包含头文件:

    #include
    
    • 1
    函数如果它的参数复合下列条件就返回真(一个非零数字)
    iscntrl任何控制字符
    任何控制字符空白字符:空格’ ‘,换页’\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 str[] = "Test String";
    	char c;
    	int i = 0;
    	while (str[i])
    	{
    		c = str[i];
    		if (islower(c))
    			c = c - 32;
    		putchar(c);
    		i++;
    	}
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    运行结果

    TEST STRING.
    
    • 1

    2、字符转换函数

    int tolower ( int c ); //将参数传进去的⼩写字⺟转⼤写
    int toupper ( int c ); //将参数传进去的⼤写字⺟转⼩写
    
    • 1
    • 2

    我们知道,将小写字母转换成大写是-32,大写字母转换成小写字母是+32

    那么,现在有了字符转换函数,就可以直接实现

    #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;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    运行结果

    TEST STRING.
    
    • 1

    二、字符串函数

    1、strlen

    概述

    size_t strlen ( const char * str );
    
    • 1

    • 字符串以 ‘\0’ 作为结束标志,strlen函数返回的是在字符串中 ‘\0’ 前⾯出现的字符个数(不包含 ‘\0’ )。
    • 参数指向的字符串必须要以 ‘\0’ 结束。
    • 注意函数的返回值为size_t,是⽆符号的( 易错 )
    • 学会strlen函数的模拟实现

    模拟实现

    法1:

    #include
    #include
    #include
    
    size_t my_strlen(const char* str)
    {
    	int count = 0;
    	assert(str);
    	while (*str)
    	{
    		count++;
    		str++;
    	}
    	return count;
    }
    
    int main()
    {
    	char arr[] = "abc";
    	size_t len = my_strlen(arr);
    	printf("%zd\n", len);
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    法2:

    #include
    #include
    #include
    
    size_t my_strlen(const char* str)
    {
    	assert(str);
    	if (*str == '\0')
    		return 0;
    	else
    		return 1 + my_strlen(str + 1);
    }
    
    int main()
    {
    	char arr[] = "abc";
    	size_t len = my_strlen(arr);
    	printf("%zd\n", len);
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    法3:

    #include
    #include
    #include
    
    size_t my_strlen(char* s)
    {
    	char* p = s;
    	while (*p)
    		p++;
    	return p - s;
    }
    
    int main()
    {
    	char arr[] = "abc";
    	size_t len = my_strlen(arr);
    	printf("%zd\n", len);
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    2、strcpy

    概述

    char * strcpy ( char * destination, const char * source );
    
    • 1

    • 源字符串必须以 ‘\0’ 结束。
    • 会将源字符串中的 ‘\0’ 拷⻉到⽬标空间。
    • ⽬标空间必须⾜够⼤,以确保能存放源字符串。
    • ⽬标空间必须可变。
    • 学会模拟实现。

    模拟实现

    char my_strcpy(char* dest, const char* src)
    {
    	char* ret = dest;
    	assert(dest);
    	assert(src);
    	while (*dest++ = *src++)
    	{
    		;
    	}
    	return ret;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    3、strcat

    概述

    • 源字符串必须以 ‘\0’ 结束。
    • ⽬标字符串中也得有 \0 ,否则没办法知道追加从哪⾥开始。
    • ⽬标空间必须有⾜够的⼤,能容纳下源字符串的内容。
    • ⽬标空间必须可修改。

    模拟实现

    char my_strcat(char* dest, const char* src)
    {
    	char* ret = *src;
    	assert(dest);
    	assert(src);
    	while (*dest)
    	{
    		dest++;
    	}
    	while (*dest++ = *src)
    	{
    		;
    	}
    	return ret;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    3、strcmp

    概述

    标准规定:
    ◦ 第⼀个字符串⼤于第⼆个字符串,则返回⼤于0的数字
    ◦ 第⼀个字符串等于第⼆个字符串,则返回0
    ◦ 第⼀个字符串⼩于第⼆个字符串,则返回⼩于0的数字

    模拟实现

    int my_strcmp(const char* arr1, const char* arr2)
    {
    	assert(arr1);
    	assert(arr2);
    	while (*arr1 == *arr2)
    	{
    		if (*arr1 == '\0')
    			return 0;
    		arr1++;
    		arr2++;
    	}
    	return *arr1 - *arr2;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    4、有限制的字符串函数

    前面1-3学习字符串函数,但是那些字符串函数没有个数限制,不安全

    下面小编带大家了解一下有个数限制的字符串函数

    strncpy

    char * strncpy ( char * destination, const char * source, size_t num );
    
    • 1

    • 拷⻉num个字符从源字符串到⽬标空间。

    • 如果源字符串的⻓度⼩于num,则拷⻉完源字符串之后,在⽬标的后边追加0,直到num个。

    strncat

    char * strncat ( char * destination, const char * source, size_t num );
    
    • 1
    #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;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    strncmp

    int strncmp ( const char * str1, const char * str2, size_t num );
    
    • 1

    ⽐较str1和str2的前num个字符,如果相等就继续往后⽐较,最多⽐较num个字⺟,如果提前发现不⼀
    样,就提前结束,⼤的字符所在的字符串⼤于另外⼀个。如果num个字符都相等,就是相等返回0.

    4、strstr

    概述

    char * strstr ( const char *, const char * );
    
    • 1

    在字符串中找一个子字符串

    返回str2在str1中第一次出现的位置
    如果str2在str1中没有出现,就返回NULL

    模拟实现

    #include
    #include
    #include
    
    const char* my_strstr(const char* str1, const char * str2)
    {
    	assert(str1);
    	assert(str2);
    
    	const char* cp = str1;
    	const char* s1 = NULL;
    	const char* s2 = NULL;
    
    	//如果子串是空字符串,直接返回str1
    	if (*str2 == '\0')
    		return str1;
    
    	while (*cp)
    	{
    		s1 = cp;
    		s2 = str2;
    		while (*s1 == *s2 && *s1 && *s2)
    		{
    			s1++;
    			s2++;
    		}
    
    		if (*s2 == '\0')
    			return cp;
    
    		cp++;
    	}
    
    	return NULL;
    }
    
    int main()
    {
    	char arr1[] = "abbbcdef";
    	char arr2[] = "bbc";
    	char* ret = my_strstr(arr1, arr2);
    	if (ret != NULL)
    		printf("%s\n", ret);
    	else
    		printf("找不到\n");
    
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48

    图解:
    在这里插入图片描述

    在这里插入图片描述

  • 相关阅读:
    Spring MVC 请求映射路径的配置,实现前后端交互
    K_A04_001 基于单片机驱动LCD1602字符滚动显示(8位并行+IIC通信)
    如何使用Postman调试HMS Core推送接口?
    【数据结构】链表的学习总结
    我的十年编程路 2013年篇
    Java毕业设计-疫情防控系统
    滴滴9.17笔试题复盘(差分数组和前缀和数组)
    RecursionError: maximum recursion depth exceeded while calling a Python object
    WAF简介
    [ALI-签约代扣] 小程序环境下的签约代扣
  • 原文地址:https://blog.csdn.net/weixin_73397765/article/details/132779720