C语言:ctype和string库中的部分常用函数的应用和实现

2024-03-11 00:20

本文主要是介绍C语言:ctype和string库中的部分常用函数的应用和实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        在编程过程中,我们经常要处理字符和字符串,C语言标准库中就提供了一系列的库函数,便于我们操作库函数。

字符分类函数

        C语⾔中有⼀系列的函数是专⻔做字符分类的,也就是⼀个字符是属于什么类型的字符的。这些函数的使⽤都需要包含⼀个头⽂件是 ctype.h

 这些函数的使⽤⽅法⾮常类似,我们一一个函数为例,各位理解后可以去类比使用:

        islower 是一个能够判断参数部分的 形参是否是⼩写字⺟的函数。通过返回值来说明是否是⼩写字⺟,如果是⼩写字⺟就返回⾮0的整数,如果不是⼩写字⺟,则返回 0。

练习:写⼀个代码,将字符串中的⼩写字⺟转⼤写,其他字符不变。

法一:

#include<stdio.h>
int main()
{char arr[] = "What can I say, man!!!";int i = 0;while (arr[i] != '\0'){if (arr[i] <= 122 && arr[i] >= 97){arr[i] -= 32;}i++;}printf("%s\n", arr);return 0;
}

        本段代码利用的使小写字母的ascii值的范围进行操作,我们可以利用islower函数。

法二:

#include<stdio.h>
#include<ctype.h>
int main()
{char arr[] = "What can I say, man!!!";int i = 0;while (arr[i] != '\0'){if (islower(arr[i])){arr[i] -= 32;}putchar();i++;}printf("%s\n", arr);return 0;
}

字符转换函数

C语言中由两个字符转换函数:

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

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

了解了字符转换函数的用法后,我们可以修改一下上面的练习:

#include<stdio.h>
#include<ctype.h>
int main()
{char arr[] = "What can I say, man!!!";int i = 0;char c;while (arr[i] != '\0'){c = arr[i];if (islower(arr[i])){c = toupper(arr[i]);}putchar(c);i++;}return 0;
}

strlen函数的使用和模拟实现

strlen

函数原型:size_t strlen ( const char * str );

strlen的使用

#include<stdio.h>
#include<string.h>
int main()
{char arr[] = "abcdef";int ret = strlen(arr);printf("%d\n",ret);//6return 0;
}

 注意事项:

• 字符串以 '\0' 作为结束标志,strlen函数返回的是在字符串中 '\0' 前⾯出现的字符个数(不包
含 '\0' )。
• 参数指向的字符串必须要以 '\0' 结束。
• 注意函数的返回值为size_t,是⽆符号的( 易错 )
• strlen的使⽤需要包含头⽂件 string.h

strlen函数的模拟实现

法一:计数器法

//(创建变量)计数器版本
#include<stdio.h>
#include<assert.h>
void my_strlen(const char* str)
{assert(str != NULL);int count = 0;while (*str != '\0'){count++;str++;}printf("%d\n", count);
}
int main()
{char arr[] = "abcdef";my_strlen(arr);return 0;
}

法二:指针-指针(结果的绝对值使两指针之间的元素个数)

#include<stdio.h>
#include<assert.h>
int my_strlen(const char* str)
{assert(str);char* ret = str;while (*str != '\0')str++;return str - ret;
}
int main()
{char arr[] = "abcdef";int ret = my_strlen(arr);printf("%d\n", ret);return 0;
}

法三:递归法

//递归法(无需创建变量)
#include<stdio.h>
#include<assert.h>
int my_strlen(const char* str)
{assert(str);if (*str == '\0')return 0;else{return 1 + my_strlen(str + 1);}
}
int main()
{char arr[] = "abcdef";int ret = my_strlen(arr);printf("%d\n", ret);return 0;
}

strcpy函数的使用和模拟实现

strcpy的使用

#include<stdio.h>
#include<string.h>
int main()
{char arr1[20] = "************";char arr2[] = "world";strcpy(arr1, arr2);printf("%s\n", arr1);return 0;
}

运行结果:

 注意事项:

• 源字符串必须以 '\0' 结束。
• 会将源字符串中的 '\0' 拷⻉到⽬标空间。
• ⽬标空间必须⾜够⼤,以确保能存放源字符串。
• ⽬标空间必须可修改。

strcpy的模拟实现

#include<stdio.h>
#include<assert.h>
//原版本
//char* my_strcpy(char* dest, const char* src)
//{
//	char* ret = dest;
//	while (*src != '\0')
//	{
//		*dest = *src;
//		dest++;
//		src++;
//	}
//	return ret;
//}
优化版本
char* my_strcpy(char* dest, const char* sorce)
{assert(dest && sorce);char* ret = dest;while (*dest++ = *sorce++);//结果相同但极大缩减了代码return ret;
}
int main()
{char arr1[20] = "*********";char arr2[] = "hello world";char* ret = my_strcpy(arr1, arr2);printf("%s\n", ret);return 0;
}

strcat函数的使用和模拟实现

strcat的使用

//strcat
#include<stdio.h>
#include<string.h>
int main()
{char arr1[20] = "hello ";char arr2[] = "world";char* ret = strcat(arr1, arr2);printf("%s\n", ret);return 0;
}

 注意事项:

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

模拟实现strcat函数

//strcat函数的模拟实现
#include<stdio.h>
#include<assert.h>
char* my_strcat(char* dest, const char* src)
{assert(dest && src);char* ret = dest;while (*dest != '\0')dest++;while (*dest++ = *src++);return ret;
}
int main()
{char arr1[20] = "hello ";char arr2[] = "world";char* ret = my_strcat(arr1, arr2);printf("%s\n", ret);return 0;
}

这篇关于C语言:ctype和string库中的部分常用函数的应用和实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/796005

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

MyBatis常用XML语法详解

《MyBatis常用XML语法详解》文章介绍了MyBatis常用XML语法,包括结果映射、查询语句、插入语句、更新语句、删除语句、动态SQL标签以及ehcache.xml文件的使用,感兴趣的朋友跟随小... 目录1、定义结果映射2、查询语句3、插入语句4、更新语句5、删除语句6、动态 SQL 标签7、ehc

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、