【C语言】字符函数和字符串函数,详解,进来就会!

news2024/12/30 3:12:21

🔥博客主页🔥:【 坊钰_CSDN博客 】

欢迎各位点赞👍评论✍收藏⭐

目录

 1. 字符分类函数

2. 字符转换函数

3. strlen的使⽤和模拟实现

3.1 采用指针-指针方式

 3.2 采用递归方式

3.3 采用计数器方式

4. strcpy的使⽤和模拟实现

5. strcat的使⽤和模拟实现

6. strcmp的使⽤和模拟实现

7. strstr的使⽤和模拟实现

8. 小结


 1. 字符分类函数

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

 些函数的使⽤⽅法⾮常类似,我们就讲解⼀个函数的事情,其他的⾮常类似:

  1. islower函数---->能够判断参数部分的字母是否是⼩写字⺟的
  2. 通过返回值来说明是否是⼩写字⺟,如果是⼩写字⺟就返回⾮0的整数,如果不是⼩写字⺟,则返回 0

下面看一个代码,将字符串中的⼩写字⺟转⼤写;

#include <stdio.h>
#include <ctype.h>
int main ()
{
 int i = 0;
 char str[] = "Test String.\n";
 char c;
 while (str[i])
 {
 c = str[i];
 if (islower(c)) 
 c -= 32;
 putchar(c);
 i++;
 }
 return 0;
}

2. 字符转换函数

C语⾔提供了2个字符转换函数:

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

有了转换函数,就可以直接使⽤tolower函数

#include <stdio.h>
#include <ctype.h>
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;
}

3. strlen的使⽤和模拟实现

前面有讲过,这次在讲一遍,将用3种方法解决;

size_t strlen ( const char * str )
  1. 字符串以 '\0' 作为结束标志,strlen函数返回的是在字符串中 '\0' 前⾯出现的字符个数(不包含 '\0' )
  2. 参数指向的字符串必须要以 '\0' 结束
  3. 注意函数的返回值为size_t,是⽆符号的
  4. strlen的使⽤需要包含头⽂件
  5.  学会strlen函数的模拟实现

3.1 采用指针-指针方式

int my_strlen(char *s)
{
 assert(str);
 char *p = s;
 while(*p != ‘\0’ )
 p++;
 return p-s;
}

 3.2 采用递归方式

int my_strlen(const char * str)
{
 assert(str);
 if(*str == '\0')
 return 0;
 else
 return 1+my_strlen(str+1);
}

3.3 采用计数器方式

int my_strlen(const char * str)
{
 int count = 0;
 assert(str);
 while(*str)
 {
 count++;
 str++;
 }
 return count;
}

4. strcpy的使⽤和模拟实现

char* strcpy(char * destination, const char * source )
  1. 源字符串必须以 '\0' 结束
  2. 会将源字符串中的 '\0' 拷⻉到⽬标空间
  3. ⽬标空间必须⾜够⼤,以确保能存放源字符串
  4. ⽬标空间必须可修改。
  5. 学会模拟实现
#include <stdio.h>

char* my_strcpy(char* arr,const char* str)
{
	char* ret = arr;
	while ((*arr++ = *str++))
	{
		;
	}
	return ret;
}

int main()
{
	char arr[100];
	char* str = "abcdefg";
	char* p = my_strcpy(arr, str);
	printf("%s", p);
	return 0;
}

5. strcat的使⽤和模拟实现

char * strcat ( char * destination, const char * source )
  1. 源字符串必须以 '\0' 结束
  2. ⽬标字符串中也得有 \0 ,否则没办法知道追加从哪⾥开始
  3. ⽬标空间必须有⾜够的⼤,能容纳下源字符串的内容
  4. ⽬标空间必须可修改
  5. 实现模拟函数
#include <stdio.h>

char* my_strcat(char* arr, const char* str)
{
	char* ret = arr;
	while (*arr)
	{
		arr++;
	}
	while ((*arr++ = *str++))
	{
		;
	}
	return ret;
}

int main()
{
	char arr[100]="abc";
	char* str = "defg";
	char* p = my_strcat(arr, str);
	printf("%s", p);
	return 0;
}

6. strcmp的使⽤和模拟实现

int strcmp ( const char * str1, const char * str2 )

  1. 第⼀个字符串⼤于第⼆个字符串,则返回⼤于0的数字
  2. 第⼀个字符串等于第⼆个字符串,则返回0
  3. 第⼀个字符串⼩于第⼆个字符串,则返回⼩于0的数字
#include <stdio.h>

int my_strcmp(char* arr, char* str)
{
	while (*arr == *str)
	{
		if (*arr == 0)
			return 0;
		arr++;
		str++;
	}
	return *arr - *str;
}


int main()
{
	char arr[] = "abcdefg";
	char str[] = "abcd";
	int ret = my_strcmp(arr, str);
	if (ret > 0)
	{
		printf("字符串arr更大!");
	}
	else if (ret < 0)
	{
		printf("字符串str更大!");
	}

	else
	{
		printf("两个字符串一样大!");
	}
	return 0;
}

7. strstr的使⽤和模拟实现

char * strstr ( const char * str1, const char * str2)
  1. 返回指向 str1 中首次出现的 str2 的指针,如果 str2 不是 str1 的一部分,则返回空指针
  2. 匹配过程不包括终止 null 字符
#include <stdio.h>

char* my_strstr(const void* arr, const void* str)
{
	const char* p1 = NULL;
	const char* p2 = NULL;
	const char* cur = arr;
	while (*cur)
	{
		p1 = cur;
		p2 = str;
		while (*p1 != '\0'&& * p2 != '\0'&& * p1 == *p2)
		{
			p1++;
			p2++;
		}

		if (*p2 == '\0')
		{
			return cur;
		}
		cur++;
	}
	return NULL;
}

int main()
{
	char arr[] = "abbbcdef";
	char str[] = "bbc";
	char* ret = my_strstr(arr, str);
	if (ret == NULL)
	{
		printf("找不到!");
	}
	else
	{
		printf("%s", ret);
	}
	return 0;
}

8. 小结

以上就是关于字符函数和字符串函数的内容了,具体还需宝子们去实践,如果觉得该博客对你有用的话,希望一键三连,点个关注不迷路,谢谢支持! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1604965.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何在本地创建一个贪吃蛇小游戏node.js服务并实现无公网IP远程游玩

文章目录 前言1.安装Node.js环境2.创建node.js服务3. 访问node.js 服务4.内网穿透4.1 安装配置cpolar内网穿透4.2 创建隧道映射本地端口 5.固定公网地址 正文开始前给大家推荐个网站&#xff0c;前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽…

荔枝派LicheePi 4A RISCV板子支持的好玩的AI模型

荔枝派LicheePi 4A 是基于 Lichee Module 4A 核心板的 高性能 RISC-V Linux 开发板&#xff0c;以 TH1520 为主控核心&#xff08;4xC9101.85G&#xff0c; RV64GCV&#xff0c;4TOPSint8 NPU&#xff0c; 50GFLOP GPU&#xff09;&#xff0c;板载最大 16GB 64bit LPDDR4X&…

mysql查看数据库表容量大小

【推荐】单表行数超过 500 万行或者单表容量超过 2GB&#xff0c;才推荐进行分库分表。 说明&#xff1a;如果预计三年后的数据量根本达不到这个级别&#xff0c;请不要在创建表时就分库分表。 1. 查询所有数据库记录数和容量 SELECTtable_schema AS 数据库,SUM(table_rows) …

MySQL高级(性能分析-查看执行频次、慢查询日志)

目录 1、SQL性能分析 1.1、SQL执行频率 1.2、慢查询日志 1、SQL性能分析 1.1、SQL执行频率 MySQL 客户端连接成功后&#xff0c;通过 show [ session | global ] status 命令可以提供服务器状态信息。通过如下指令&#xff0c;可以查看当前数据库的 insert、update、delete、…

物理页采样内核配置damon和perf

一、安装报错Missing file: arch/x86/boot/bzImage [sudo] password for xmu: arch/x86/Makefile:142: CONFIG_X86_X32 enabled but no binutils support sh ./arch/x86/boot/install.sh 5.15.19-htmm-test1 \arch/x86/boot/bzImage System.map "/boot"*** Missing…

电商网站建设开发

随着互联网技术的飞速发展&#xff0c;电子商务已经成为一种全新的商业模式&#xff0c;许多传统的企业也开始涉足电商领域。对于想要进行网络销售的企业来说&#xff0c;电商网站建设开发是非常重要的环节。下面将从几个方面介绍电商网站建设开发的必要性和关键点。 一、 提升…

[入门]测试原则-ApiHug准备-测试篇-006

&#x1f917; ApiHug {Postman|Swagger|Api...} 快↑ 准√ 省↓ GitHub - apihug/apihug.com: All abou the Apihug apihug.com: 有爱&#xff0c;有温度&#xff0c;有质量&#xff0c;有信任ApiHug - API design Copilot - IntelliJ IDEs Plugin | Marketplace 写在前面…

2024年机电一体化与交通运输国际学术会议(IACMIT 2024)

2024年机电一体化与交通运输国际学术会议&#xff08;IACMIT 2024) 2024 International Conference on Mechatronics Integration and Transportation 一、【会议简介】 2024年机电一体化与交通运输国际学术会议&#xff0c;是关于交通运输机械工程和机电控制技术的交流盛会。 …

neo4j使用详解(终章、neo4j的java driver使用模板及工具类——<可用于生产>)

Neo4j系列导航: neo4j安装及简单实践 cypher语法基础 cypher插入语法 cypher插入语法 cypher查询语法 cypher通用语法 cypher函数语法 neo4j索引及调优 neo4j java Driver等更多 1. 简介 本文主要是java使用neo4j driver操作neo4j的模板项目及非常有用的工具类,主要包括: 图…

存储过程的创建和调用及删除

目录 存储过程 存储过程的创建 存储过程的调用及删除 在 SQL Plus 中调用存储过程 在 PL/SQL 块中调用存储过程 存储过程的删除 Oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645 存储过程 存储过程是一种命名的 PL/S…

57、通过EEG数据的SHAPE变化,揭开EEG-TCNet的黑匣子[看好了小子,我只教这一次]

之前在第18篇博客中对于EEG-TCNet这个处理EEG信号的sota模型进行了介绍&#xff0c;也给出了模型&#xff0c;目前也是全网对于EEG-TCNet浏览度最高的文章了&#xff0c;我觉得讲的已经很细致了&#xff0c;没想到还是有不少同学疑问&#xff0c;这也是全网缺少该模型pytorch代…

PLC通讯革新:EtherNetIP转PROFINET网关在工业现场的应用指南

通讯革新&#xff1a;通过Profinet和Ethernet/IP网关实现PLC与PLC之间进行通讯 在工业自动化领域&#xff0c;PLC扮演着至关重要的角色。随着技术的不断进步&#xff0c;PLC通讯协议的兼容性变得越来越重要。本文将详细介绍如何通过Profinet和Ethernet/IP网关&#xff0c;将罗克…

2024年Q1季度冰箱行业线上市场销售数据分析

Q1季度冰箱线上市场表现不如预期。 根据鲸参谋数据显示&#xff0c;2024年1月至3月线上电商平台&#xff08;京东天猫淘宝&#xff09;冰箱累计销量约410万件&#xff0c;环比下降11%&#xff0c;同比下降21%&#xff1b;累计销售额约98亿元&#xff0c;环比下降31%&#xff0…

外包干了16天,技术倒退明显

先说情况&#xff0c;大专毕业&#xff0c;18年通过校招进入湖南某软件公司&#xff0c;干了接近6年的功能测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落&#xff01; 而我已经在一个企业干了四年的功能…

十:深入理解 CyclicBarrier—— 栅栏锁

目录 1、CyclicBarrier 入门1.1、概念1.2、案例 2、CyclicBarrier 源码分析2.1、类结构2.2、await() 方法 —— CyclicBarrier2.2.1、dowait() 方法 —— CyclicBarrier2.2.1.1、breakBarrier() 方法 —— CyclicBarrier2.2.1.2、nextGeneration() 方法 —— CyclicBarrier 3、…

“400G网络:QSFP-DD的登场,谁主沉浮?”

&#x1f31f;QSFP-DD 作为400G 光模块的最小外形尺寸&#xff0c;提供业界最高的带宽密度&#xff0c;同时利用对低速 QSFP 可插拔模块和电缆的向后兼容性&#xff0c;使其在光纤制造商中很受欢迎。作为400G高速应用中最新的热门光收发器&#xff0c;QSFP-DD经常被拿来与QSFP5…

九州金榜|家庭教育中如何疏导孩子抑郁情绪?

在家庭教育的过程中&#xff0c;孩子抑郁情绪的疏导是一项至关重要的任务。抑郁情绪不仅会影响孩子的心理健康&#xff0c;还可能对其学习、生活和人际关系产生负面影响。因此&#xff0c;家长需要积极关注孩子的情绪变化&#xff0c;采取有效的措施来疏导孩子的抑郁情绪。下面…

【位运算】Leetcode 只出现一次的数字 ||

题目解析 137. 只出现一次的数字 II 算法讲解 nums中要么一个数字出现三次&#xff0c;一个数字出现一次&#xff0c;按照比特位来说只可能出现上面的四种情况&#xff1a; 3n个0 0 或者 3n个0 1 或者 3n个1 0 或者 3n个1 1&#xff0c;它们相加的结果依次是0&#xff0c;…

虚拟机数据恢复—KVM虚拟机磁盘文件数据恢复案例

虚拟化数据恢复环境&故障&#xff1a; KVM是Kernel-based Virtual Machine的简称&#xff0c;是一个开源的系统虚拟化模块&#xff0c;自Linux2.6.20版本之后集成在Linux的各个主要发行版本中。KVM使用Linux自身的调度器进行管理。 本案例中的服务器操作系统为Linux&#x…

LInux下C语言模拟实现 —— 极简版的命令行解释器

根据对进程的理解&#xff0c;我们知道然后去使用系统接口去调用程序和加载程序&#xff0c;因此我们可以利用接口去实现一个简易版的命令行解释器&#xff0c;核心思路就是获取用户输入的指令信息&#xff0c;然后利用指令信息去调用相关的接口&#xff0c;因此首先就是要如何…