【C语言】长篇详解,字符系列篇1-----“混杂”的各种字符类型字符转换和strlen的模拟实现【图文详解】

本文主要是介绍【C语言】长篇详解,字符系列篇1-----“混杂”的各种字符类型字符转换和strlen的模拟实现【图文详解】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

欢迎来CILMY23的博客喔,本期系列为【C语言】长篇详解,字符系列篇1-----“混杂”的各种字符函数……,图文讲解各种字符函数,带大家更深刻理解C语言中各种字符函数的应用,感谢观看,支持的可以给个赞哇。

前言

在C语言中,我们常常碰见各种字符,也需要对字符进行处理,那C语言提供了一系列的库函数,来帮助我们处理各种情况。字符函数有字符串函数,字符分类函数,还有字符转换函数……

一、字符分类函数 

C语言中有一系列的函数是专门做字符分类的,也就是一个字符是属于什么类型的字符的。 这些函数的使用都需要包含一个头文件是ctype . h,字符分类函数有以下这些:

名称判断的字符
1iscntrl任何控制字符
2isspace空白字符:空格'符 ' ',换页'\ f',换行‘\n’,回车'\r',制表符‘\t’,或者垂直制表符'\v'
3isdigit十进制数字 0 ~9
4isxdigit 十六进制数字,包括所有十进制数字,小写字符a~f,大写字母A~F
5islower小写字母a~z
6isupper大写字母A~Z
7isalpha字母a~z或者A~Z
8isalnum字母或者数字,a~z,A~Z,0~9
9ispunct标点符号,任何不属于数字或者字母的图形字符(可打印)
10isgraph任何图形字符
11isprint任何可打印字符,包括图形字符和空白字符

以上这些函数都可以在cplusplus查找到cplusplus.com

 接下来我们看一个函数,islower,其实这种分类函数都有一个特点,它们是只有一个参数,int c

它的意思是,是这种字符就返回真,不是就返回假。 

这是islower的函数介绍:

 这是函数return value和例子:

那我们具体看看这个函数的返回值吧:

#include<ctype.h>
#include <stdio.h>int main()
{int ret = islower('a');printf("%d\n",ret);ret = islower('b');printf("%d\n", ret);ret = islower('z');printf("%d\n", ret);ret = islower('Q');printf("%d\n", ret);return 0;}

我们可以看到结果如下所示:

 

也就是我们通过返回值判断是否是小写字母,,如果是小写字母就返回非0的整数,如果不是小写字母,则返回 0。

实际运用情况:需要判断一个字符数组中是否包含小写字母,如果是则打印该小写字母

按照以往情况我们都需要用一个if语句写条件去判断,但现在学了这个islower之后就可以简化我们的条件如下:

#include<ctype.h>
#include <stdio.h>int main()
{int i = 0;char ch[] = "12SilLmy23 ";while (ch[i]){//if(ch[i] >= 'a' &&ch[i] <= 'z')if (islower(ch[i])){printf("%c ", ch[i]);}i++;}return 0;}

 结果如下:

这样的简化更有利于我们去阅读代码,让代码更简洁点。同样如果是字母大小写转换,我们同样可以用分类函数,先分类,后进行整数相加减的形式来把字母大小写转换。 

二、字符转换函数

 那碰到字母大小写转换呢,C语言库函数又提供了两种字符转换函数

名称用途
1int tolower( int c);大写字母转换成小写字母
2int toupper( int c);小写字母转换成大写字母

 我们来看以下例子:

#include<ctype.h>
#include <stdio.h>int main()
{int i = 0;char ch[] = "12SilLmy23 ";while (ch[i]){printf("%c ",tolower( ch[i]));i++;}i = 0;printf("\n");while (ch[i]){printf("%c ", toupper(ch[i]));i++;}return 0;}

结果:

 

tolower将大写字母全都转换成了小写字母,而toupper都将小写字母转换成了大写字母。 这就是C库函数提供的转换函数。

三、strlen的总结和模拟实现

strlen的模拟实现呢,我们在指针系列篇讲过捏, http://t.csdnimg.cn/LF1Hl(一、strlen的模拟实现)

strlen:

size_t strlen ( const char * str );

strlen它的功能是获取字符串的长度,返回字符串的长度。那字符串的特点是在“”的末尾有一个\0,所以我们可以采取计数的方式来统计字符串的长度。或者用指针减指针的方式模拟实现。其次我们要注意的是,strlen它的返回类型是size_t。为什么要注意它的返回类型是size_t呢?

我们看以下代码:

#include <stdio.h>
#include <string.h>int main()
{char ch1[] = "CILmy23 ";char ch2[] = "CI";if ((strlen(ch2) - strlen(ch1) )> 0){printf(" > ");}else{printf(" < =");}return 0;}

本来我们所期待的结果是输出<=,但是结果输出的却是

 

这是因为数据类型是无符号整型,无论是负数还是正数,都会被认为是>= 0的数,如果我们将其数据类型搞成int类型,就能输出< = 

那在这里我也会重新展开详写strlen的几种实现方式。

第一种采用变量计数方式:

size_t my_strlen(const char* str)
{assert(str);int len = 0;while (*str != '\0'){len++;str++;}return len;
}

逻辑图如下所示: 

 

这是一种采用指针+变量的形式来实现的,我们通过一个变量记录下我们循环的次数,循环的次数就是字符串的长度,最后返回变量的值。 虽然图没有画,但是走完循环后str是停在'\0'上的。

第二种不使用变量计数方式:

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

这是一种采用递归的形式完成的,省去变量,但是计算大的字符串的时候效率可能会比较低下,我们一般不采用这种形式。 

第三种使用指针减去指针计数方式:

size_t my_strlen(const char* str)
{assert(str);const char* tail = str;while (*tail != '\0'){tail++;}return tail - str;
}

逻辑图如下: 

 

 这种方法思路应用比较多,双指针变式也比较多。

总结:

1.strlen的功能是求字符串长度,统计的是到'\0' 之前的字符长度

2.字符串的长度中必须要有'\0'

3.要注意strlen它的返回类型是size_t

4.使用记得包括头文件string.h

感谢各位同伴的支持,本期字符函数篇1就讲解到这啦,内容较少,下期我们将从strcpy开始讲起,如果你觉得写的不错的话,可以给个赞,若有不足,欢迎各位在评论区讨论。  

这篇关于【C语言】长篇详解,字符系列篇1-----“混杂”的各种字符类型字符转换和strlen的模拟实现【图文详解】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

LangChain转换链:让数据处理更精准

1. 转换链的概念 在开发AI Agent(智能体)时,我们经常需要对输入数据进行预处理,这样可以更好地利用LLM。LangChain提供了一个强大的工具——转换链(TransformChain),它可以帮我们轻松实现这一任务。 转换链(TransformChain)主要是将 给定的数据 按照某个函数进行转换,再将 转换后的结果 输出给LLM。 所以转换链的核心是:根据业务逻辑编写合适的转换函

十四、观察者模式与访问者模式详解

21.观察者模式 21.1.课程目标 1、 掌握观察者模式和访问者模式的应用场景。 2、 掌握观察者模式在具体业务场景中的应用。 3、 了解访问者模式的双分派。 4、 观察者模式和访问者模式的优、缺点。 21.2.内容定位 1、 有 Swing开发经验的人群更容易理解观察者模式。 2、 访问者模式被称为最复杂的设计模式。 21.3.观察者模式 观 察 者 模 式 ( Obser

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

通过SSH隧道实现通过远程服务器上外网

搭建隧道 autossh -M 0 -f -D 1080 -C -N user1@remotehost##验证隧道是否生效,查看1080端口是否启动netstat -tuln | grep 1080## 测试ssh 隧道是否生效curl -x socks5h://127.0.0.1:1080 -I http://www.github.com 将autossh 设置为服务,隧道开机启动

【操作系统】信号Signal超详解|捕捉函数

🔥博客主页: 我要成为C++领域大神🎥系列专栏:【C++核心编程】 【计算机网络】 【Linux编程】 【操作系统】 ❤️感谢大家点赞👍收藏⭐评论✍️ 本博客致力于知识分享,与更多的人进行学习交流 ​ 如何触发信号 信号是Linux下的经典技术,一般操作系统利用信号杀死违规进程,典型进程干预手段,信号除了杀死进程外也可以挂起进程 kill -l 查看系统支持的信号

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测 目录 时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测基本介绍程序设计参考资料 基本介绍 MATLAB实现LSTM时间序列未来多步预测-递归预测。LSTM是一种含有LSTM区块(blocks)或其他的一种类神经网络,文献或其他资料中LSTM区块可能被描述成智能网络单元,因为

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

Jitter Injection详解

一、定义与作用 Jitter Injection,即抖动注入,是一种在通信系统中人为地添加抖动的技术。该技术通过在发送端对数据包进行延迟和抖动调整,以实现对整个通信系统的时延和抖动的控制。其主要作用包括: 改善传输质量:通过调整数据包的时延和抖动,可以有效地降低误码率,提高数据传输的可靠性。均衡网络负载:通过对不同的数据流进行不同程度的抖动注入,可以实现网络资源的合理分配,提高整体传输效率。增