C语言——字符函数与字符串函数

正文开始:在编程过程中,我们经常要处理字符和字符串,为了方便操作字符和字符串,C语⾔标准库中提供了 一系列库函数,接下来我们就学习⼀下这些函数。

1. 字符分类函数

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

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

 int islower ( int c );
//返回int类型
//判断c是否为小写字母
//为真则返回非0整数
练习:
写⼀个代码,将字符串中的小写字⺟转⼤写,其他字符不变。
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<ctype.h>


int main() {
	char arr[] = "abdGysHJs";
	char c;
	int i = 0;
	while (arr[i]) {
		c = arr[i];
		if (islower(c))//判断是否为小写字母,为真则执行if语句
		{
			c -= 32;
			arr[i] = c;
		}
		i++;
	}
	printf("%s", arr);
	return 0;
}

2.字符转换函数

C语言提供了2个字符转换函数:
int tolower ( int c ); //将参数传进去的大写字母转小写
int toupper ( int c ); //将参数传进去的小写字母转大写
对于上面的函数,我们是利用大小写的ASCII码值差32,有了转换函数,我们就可以直接使用tolower转换。

试试看吧

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<ctype.h>


int main() {
	char arr[] = "abdGysHJs";
	char c;
	int i = 0;
	while (arr[i]) {
		c = arr[i];
		if (islower(c))//判断是否为小写字母,为真则执行if语句
		{
			/*c -= 32;
			arr[i] = c;*/

			c = toupper(c);
			arr[i] = c;
		}
		i++;
	}
	printf("%s", arr);
	return 0;
}

3. strlen的使用和模拟实现

size_t strlen(const char* str);
注意:
  • strlen函数返回的是在字符串中 '\0' 前面出现的字符个数(不包 含 '\0' )。
  • 字符串以“\0”为结束标志
  • 参数指向的字符串必须要以 '\0' 结束
  • 注意函数的返回值(size_t),是无符号的
  • strlen函数需要包含头文件   <string.h>
  • 学会strlen的模拟实现
#include<stdio.h>
#include<string.h>


int main()
{
	char arr1[] = "abc";
	char arr2[] = "abcdef";
	if (strlen(arr1) > strlen(arr2)) {
		printf("arr1>arr2");
	}
	else {
		printf("arr1<arr2");
	}
	return 0;
}

strlen的函数实现

方法1:

#include<stdio.h>
//计数器方式
int str_char(const char* str)
{
	int count = 0;
	assert(str);
	while (*str)
	{
		count++;
		str++;
	}
	return count;
}


int main() {
	char arr1[] = "abc";
	int ret = str_char(arr1);
	printf("arr1的长度%d",ret);
	return 0;
}

方法2:

//不能创建临时变量计数器
int str_char(const char* str) {
		assert(str);
		if (*str == '\0')//判断是否为空
			return 0;
		else
			return 1 + str_char(str + 1);//这里运用了递归的思想,每次数组+1到函数里	
}

int main() {
	char arr1[] = "abc";
	int ret = str_char(arr1);
	printf("arr1的长度%d",ret);
	return 0;
}

方法3:

C语言详解指针-CSDN博客icon-default.png?t=N7T8https://blog.csdn.net/Asuku_/article/details/137690083之前学习的(数组-数组),在这里也可以发挥其作用

//指针-指针的⽅式
int str_char(char* s)
{
    assert(s);//这里的使用需要包含头文件<assert.h>,断言s是否为NULL
    char* p = s;
    while ((*p != '\0'))
        p++;
    return p - s;

}

int main() {
    char arr1[] = "abc";
    int ret = str_char(arr1);
    printf("arr1的长度%d",ret);
    return 0;
}

4. strcpy 的使用和模拟实现

char* strcpy(char * destination, const char * source );
  • 源字符串必须以 '\0' 结束。
  •  会将源字符串中的 '\0' 拷贝到目标空间。
  •  目标空间必须足够大,以确保能存放源字符串。
  •  目标空间必须可修改。
  •  学会模拟实现。

strcpy的模拟实现

#include<stdio.h>
#include<assert.h>

char* my_strcpy(char*dest,const char*src)
{
	assert(dest!=NULL);
	assert(src!=NULL);
	int sz = src[5] - src[0];
	for (int i = 0; i < sz;i++) {
		*dest = *src;
		dest++;
		src++;
	}
	return dest;
 }

int main()
{
	char arr1[5];
	char arr2[5] = "abcde";

	my_strcpy(arr1, arr2);

	return 0;
}

5. strcat 的使用和模拟实现

源字符串必须以 '\0' 结束。
目标字符串中也得有 \0 ,否则没办法知道追加从哪里开始。
目标空间必须有⾜够的大,能容纳下源字符串的内容。
目标空间必须可修改。
字符串自己给自己追加,如何?

strcat模拟实现

char* my_strcat(char* dest, const char* src)
 {
     char* ret = dest;
     assert(dest != NULL);
     assert(src != NULL);
     while (*dest)
   {
	dest++;         //找到dest的‘\0’
   }
     while ((*dest++ = *src++))
   {
	   ;
   }
   return ret;
}

6. strcmp 的使用

第⼀个字符串大于第二个字符串,则返回大于0的数字
第⼀个字符串等于第二个字符串,则返回0
第⼀个字符串小于第二个字符串,则返回小于0的数字
那么如何判断两个字符串? ⽐较两个字符串中对应位置上字符ASCII码值的大小。
strcmp函数的模拟实现:

strcmp模拟实现

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;
}

7. strncpy 函数的使用

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

对比strcpy函数,strncpy则多了size_t num;

  • 拷贝num个字符从源字符串到目标空间。
  • 如果源字符串的长度小num,则拷贝完源字符串之后,在目标的后面追加,直到num个;

8. strncat 函数的使用

char * strncat ( char * destination, const char * source, size_t num );
  • 将source指向字符串的前num个字符追加到destination指向的字符串末尾,再追加一个 \0 符。
  • 如果source 指向的字符串的长度小于num的时候,只会将字符串中到 \0 的内容追加到destination指向的字符串末尾。
/* strncat example */
#include <stdio.h>
#include <string.h>
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;
}

输出结果:   To be or not

9. strncmp函数的使用

int strncmp ( const char * str1, const char * str2, size_t num );
比较str1和str2的前num个字符,如果相等就继续往后比较,最多比较num个字⺟,如果提前发现不⼀ 样,就提前结束,大的字符所在的字符串大于另外⼀个。如果num个字符都相等,就是相等返回0.

10. strstr 的使用

char * strstr ( const char * str1, const char * str2);
  • 函数返回字符串str2在字符串str1中第一次出现的位置
  • 字符串的比较匹配不包含 \0 字符,以 \0 作为结束标志
    /* strstr example */
    #include <stdio.h>
    #include <string.h>
    int main()
    {
    	char str[] = "This is a simple\0 string";
    	char* pch;                  
    	pch = strstr(str, "simple");//存放simple以后的字符串,到\0停止
    	printf("%s\n", pch);
    	return 0;
    }

11. strtok 函数的使用

char * strtok ( char * str, const char * sep);
  • sep参数指向一个字符串,定义了用作分隔符的字符集合
  • 第一个参数指定⼀个字符串,它包含了0个或者多个由sep字符串中⼀个或者多个分隔符分割的标记。
  • strtok函数找到str中的下⼀个标记,并将其用 \0 结尾,返回⼀个指向这个标记的指针(注:strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串⼀般都是临时拷贝的内容并且可修改。)
  • strtok函数的第⼀个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置。
  • strtok函数的第⼀个参数为 NULL ,函数将在同⼀个字符串中被保存的位置开始,查找下⼀个标记。
  • 如果字符串中不存在更多的标记,则返回 NULL 指针。
#include <stdio.h>
#include <string.h>

int main()
{
	char arr[] = "192.168.6.111";
	char* sep = ".";
    char* str = NULL;
	for (str = strtok(arr, sep); str != NULL; str = strtok(NULL, sep))
		{         //在arr数组中找到 '.',返回 ( char* )该位置的指针
		          //    如果strtok函数第一个为NULL,则从该位置继续往后找
		printf("%s\n", str);
		}
	 return 0;
}

12. strerror 函数的使用

char * strerror ( int errnum );
strerror函数可以把参数部分错误码对应的错误信息的字符串地址返回来。
#include <errno.h>
#include <string.h>
#include <stdio.h>


int main()
{
	int i = 0;
	for (i = 0; i <= 10; i++) {
		printf("%s\n", strerror(i));
	}
	return 0;
}

下面就对应了各个错误:可以尝试尝试

No error
Operation not permitted
No such file or directory
No such process
Interrupted function call
Input/output error
No such device or address
Arg list too long
Exec format error
Bad file descriptor
No child processes

perror函数的使用

也可以了解⼀下perror函数,perror  函数相当于⼀次将上述代码中的第9行完成了,直接将错误信息打 印出来。perror函数打印完参数部分的字符串后,再打印一个冒号和一个空格,再打印错误信息
#include <stdio.h>
#include <string.h>
#include <errno.h>
int main()
 {
	 FILE * pFile;
	 pFile = fopen("unexist.ent", "r");
	 if (pFile == NULL)
	 perror("Error opening file unexist.ent");
	 return 0;
}

Error opening file unexist.ent: No such file or directory

oi!  点个赞走吧!!!

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

康姿百德床垫抗干扰设计,保证你和伴侣睡眠不受影响

康姿百德官网价格公开透明&#xff0c;床垫价格合理质量安全可靠 在我们的一生中&#xff0c;睡眠的时间占据我们生活的大部分。在繁忙的一天结束时&#xff0c;没有什么比沉浸在舒适床垫的温柔拥抱中更让人期待的&#xff0c;让您在睡眠过程中释放一整天的疲惫。康姿百德床垫…

AI术语大全:AGI、LLM、GenAI、GPT、ChatGPT和AIGC是什么意思?

讲动人的故事,写懂人的代码 自2022年底ChatGPT在全球AI界闪亮登场以后,你是不是经常听到AGI、LLM、GenAI、GPT和AIGC这几个词,但总是分不清它们到底是什么意思? 今天,我就用简单的话来给你讲讲这些词到底是什么意思。 AI,人工智能(Artificial Intelligence),就是让机…

科技人才的养成之路

引言 在当今科技行业蓬勃发展的背景下&#xff0c;对于高素质科技人才的需求日益增加。科技人才的培养不仅仅是为了满足市场需求&#xff0c;更是为了推动社会的科技创新和发展。正是这些科技人才&#xff0c;推动着科技的边界不断拓展&#xff0c;创造出各种令人瞩目的技术和…

HDFS [MSST‘10] 论文阅读笔记

原论文&#xff1a;The Hadoop Distributed File System (MSST’10) HDFS关键技术要点概览 设计目标&#xff1a;HDFS旨在可靠地存储大型数据集&#xff0c;并以高带宽流式传输这些数据集到用户应用程序。它通过在大量服务器上分布存储和计算资源&#xff0c;使得资源可以随着…

【计算机网络】常用编码方式+例题(曼彻斯特编码、差分曼彻斯特编码...)

常用编码方式例题 常用编码方式练习画出四种编码20221题342015题342013题34 常用编码方式 练习 画出四种编码 20221题34 这个题目的考察是差分曼彻斯特编码。 差分曼彻斯特编码在每个码元的中间时刻电平都会发生跳变。与曼彻斯特编码不同的是&#xff1a;电平的跳变仅代表时钟…

电商技术揭秘二十四:无人仓储与自动化技术

相关系列文章 电商技术揭秘一&#xff1a;电商架构设计与核心技术 电商技术揭秘二&#xff1a;电商平台推荐系统的实现与优化 电商技术揭秘三&#xff1a;电商平台的支付与结算系统 电商技术揭秘四&#xff1a;电商平台的物流管理系统 电商技术揭秘五&#xff1a;电商平台…

✯✯✯宁波CCC认证:守护产品质量,铸就企业信誉的坚实之盾✯✯✯

&#x1f396;️宁波CCC认证&#xff1a;&#x1f3c6;守护产品质量&#xff0c;&#x1f947;铸就企业信誉的坚实之盾 &#x1f34e;宁波&#xff0c;这座充满&#x1f6b5;‍♀️活力的海滨城市&#xff0c;&#x1f6a2;不仅以其独特的&#x1f3de;️地理位置和丰富的&…

【C++】C++11 lambda表达式

&#x1f440;樊梓慕&#xff1a;个人主页 &#x1f3a5;个人专栏&#xff1a;《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》《C》《Linux》《算法》 &#x1f31d;每一个不曾起舞的日子&#xff0c;都是对生命的辜负 目录 前言 C11引入『 lambda表…

蓝桥杯简单STL

目录 vector vector定义 vector访问 常用函数 size() ​编辑 push_back(num) pop_back() clear 迭代器&#xff08;iterator) 迭代器定义 遍历数组示例 insert(it, element) erase(it) 标准模板库--STL&#xff0c;它包含了多种预定义的容器、算法和迭代器&…

【Go语言快速上手(一)】 初识Go语言

&#x1f493;博主CSDN主页:杭电码农-NEO&#x1f493;   ⏩专栏分类:Go语言专栏⏪   &#x1f69a;代码仓库:NEO的学习日记&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学习更多Go语言知识   &#x1f51d;&#x1f51d; Go快速上手 1. 前言2. Go语言简介(为…

婚恋相亲交友小程序婚介红娘同城相亲交友APP源码征婚礼物线下活动

一、用户交互与活动 婚恋广场&#xff1a;用户可以在此浏览和发布自己的征婚信息。服务大厅&#xff1a;提供平台的各种服务介绍和客服支持。同城约会&#xff1a;用户可以根据地理位置找到附近的约会对象。相亲派、一线牵&#xff1a;组织相亲活动和线上配对。视频秀、真心话…

【数据结构】习题之链表中倒数第k个节点

&#x1f451;个人主页&#xff1a;啊Q闻 &#x1f387;收录专栏&#xff1a;《数据结构》 &#x1f389;前路漫漫亦灿灿 前言 今天的题目是求出链表中倒数第k个节点。 链表中倒数第k个节点 题目为&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; …

Java中队列

队列是一种常见的数据结构&#xff0c;它按照先进先出&#xff08;FIFO&#xff09;的原则管理元素。在 Java 中&#xff0c;队列通常是通过链表或数组实现的&#xff0c;不同的实现类在内部数据结构和操作上可能有所不同。 1.原理 1.数据结构&#xff1a;队列的基本数据结构…

七大设计原则

在软件开发的领域中&#xff0c;随着技术的不断进步和市场需求的不断变化&#xff0c;软件系统的设计和维护变得越来越重要。为了确保软件系统能够长期有效地运行&#xff0c;并且能够在未来的发展中适应新的需求和技术变化&#xff0c;提高软件系统的可维护性和可复用性成为了…

机器学习—特征预处理和降维(四)

什么是特征预处理&#xff1f; 通过一些转换函数将特征数据转换成更加适合算法模型的特征数据过程 1包含内容 数值型数据的无量纲化&#xff1a; 归一化标准化 2特征预处理API sklearn. preprocessing为什么要进行归一化 or 标准化&#xff1f; 特征的单位或者大小相差较大…

vue源码解析——diff算法/双端比对/patchFlag/最长递增子序列

虚拟dom——virtual dom&#xff0c;提供一种简单js对象去代替复杂的 dom 对象&#xff0c;从而优化 dom 操作。virtual dom 是“解决过多的操作 dom 影响性能”的一种解决方案。virtual dom 很多时候都不是最优的操作&#xff0c;但它具有普适性&#xff0c;在效率、可维护性之…

BackTrader 中文文档(十一)

原文&#xff1a;www.backtrader.com/ 基准测试 原文&#xff1a;www.backtrader.com/docu/observer-benchmark/benchmarking/ 票号 #89 是关于添加对资产的基准测试的。理智的做法是&#xff0c;即使有一种策略&#xff0c;即使是正的&#xff0c;也低于简单跟踪资产将提供的内…

第⑭讲:Ceph集群管理:守护进程管理、日志管理和端口号配置

文章目录 1.Ceph各组件守护进程的管理方式2.守护进程管理操作2.1.Ceph所有组件的守护进程列表2.2.重启当前主机中所有的Ceph组件2.3.重启主机中所有的Monitor组件2.4.重启指定主机的Monitor组件2.5.重启指定的OSD组件 3.Ceph的日志管理4.Ceph集群各组件的守护进程5.Ceph集群各组…

All in One:Prometheus 多实例数据统一管理最佳实践

作者&#xff1a;淡唯&#xff08;啃唯&#xff09;、阳其凯&#xff08;逸陵&#xff09; 引言 Prometheus 作为目前最主流的可观测开源项目之一&#xff0c;已经成为云原生监控的事实标准&#xff0c;被众多企业广泛应用。在使用 Prometheus 的时候&#xff0c;我们经常会遇…

自然语言处理: 第二十六章大模型基底之Mistral 8x7B

文章地址: 2401.04088.pdf (arxiv.org) 项目地址: mistralai/mistral-src: Reference implementation of Mistral AI 7B v0.1 model 前言: 本文意在一文深度剖析Mistral 8X7B的关键改进点。 Mistral AI是一个由DeepMind和Meta的三位前员工在巴黎共同创立的AI公司。其在23年…