目录

-C语言长期更新第16讲字符和字符串函数

C语言(长期更新)第16讲:字符和字符串函数

C语言(长期更新)第16讲

字符和字符串函数

跟着潼心走,轻松拿捏C语言,困惑通通走,一去不回头~欢迎开始今天的学https://i-blog.csdnimg.cn/direct/a45374f8c1584c0ca7bb11f3a2065f6f.jpeg


知识回顾

上节课我们学习了指针的全部内容,今天我们来继续学习字符函数和字符串函数,坐稳了,我们发车,gogogo,出发喽!


前言

在编程过程中,我们常常需要处理字符和字符串,为了方便处理,C语言标准库中提供了一系列库函数,也就是我们今天的学习内容

16.1 字符分类函数

专门做字符分类的函数,就是判断字符属于什么类型的函数

这些函数的使用需要包含头文件 ctype.h

如下

  • iscntrl 任何控制字符
  • isspace  空白字符
  • isdigit  十进制数字,‘0’~‘9’字符
  • isxdigit  十六进制数字,包括所有十进制数字字符,小写字母af,大写字母AF
  • islower  小写字母
  • issupper  大写字母
  • isalnum  数字或字母
  • ispunct  标点符号,任何不属于数字或字母的图形字符(可打印)
  • ispraph  任何图形字符
  • isprint   任何可打印字符,包括图形字符和空白字符

这类函数的使用方法极为类似

比如islower

https://i-blog.csdnimg.cn/direct/0752638f174b4219b700e5325c5e3212.png

返回值为int类型,小写字母就返回非0整数,不是小写字母,就返回0

练习:将字符串中小写字母转大写,其他字符不变

https://i-blog.csdnimg.cn/direct/2e484f3b1af241408cc72a1967dc1c16.png

16.2 字符转换函数

C语言提供了两种字符转换函数

https://i-blog.csdnimg.cn/direct/c95706fdcb27489fb2ed1d9973df0486.png

上面的代码我们小写转大写,用的是直接减32的方法

有了转换函数,就可以直接使用toupper函数

https://i-blog.csdnimg.cn/direct/0730db5e791845adbe06eb9cf72c28b4.png

16.3 strlen的使用和模拟实现

https://i-blog.csdnimg.cn/direct/6ef9b9cc1c6a430b86ce86ee1d04239b.png

  • 有关strlen,我们需要知道以下几个点:
  • 返回的是’\0’前的字符数
  • 要求参数指向的字符串必须有’\0’
  • 返回类型是size_t,是无符号的
  • 使用时需包含头文件string.h
  • 学会strlen函数的模拟实现

在学模拟实现之前,我们先来看一下strlen的应用

比如我们要比较两个字符串的长短,这时候不是比大小,不能用strcmp

https://i-blog.csdnimg.cn/direct/59573e665f2e4296a4cdc0079f257663.png

strlen函数的模拟实现

方式一

https://i-blog.csdnimg.cn/direct/651caf90a48c4caa8da915099d1cf968.png

方式二:不创建新的临时变量

https://i-blog.csdnimg.cn/direct/b6e92052536a41e789f6157e793bb398.png

注意使用函数递归时,函数参量要改变

方式三:

https://i-blog.csdnimg.cn/direct/45624195a5f547dcb0f8c7d3ff42d061.png

16.4 strcpy 的使用和模拟实现

https://i-blog.csdnimg.cn/direct/8358cad896c24fd192eaca273fd27697.png

如其名。strcpy是用来拷贝数组的,两个参数第一个表示拷贝的终点,即目标字符串的起始地址;

第二个表示含有要拷贝的内容的字符串起始地址,最终返回destination

几点注意:

源字符串必须以’\0’结尾

会将源字符串的‘\0’拷贝到目标空间

目标空间必须足够大,以确保能存放源字符串

目标空间必须可修改

学会模拟实现

下面进行代码演示

https://i-blog.csdnimg.cn/direct/0063744f0586494fb74c1ba120017b8c.png

这段代码还可以进行优化

https://i-blog.csdnimg.cn/direct/2e3754c447364849b3114648b42f1d7f.png

啥意思,括号中赋值表达式最终的结果是左值,当左值被赋为\0,也即ASCII码值为0时,为假,自动会跳出循环。很妙吧嘿嘿

16.5 strcat 的使用和模拟实现

在一个字符串的末尾追加字符串

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

关于最后一个问题,strcat 本身是可以做到的,但是应该是作为特殊情况处理的

这里我们就不做这方面的代码模拟了

https://i-blog.csdnimg.cn/direct/4b0b5099a37742eab5f1eff2b4370668.png

16.6 strcmp 的使用和模拟实现

比教两个字符串的大小,这可是咱的老熟人了

回顾一下

  • 第一个字符串大于第二个字符串,则返回大于0的数字
  • 第一个字符串等于第二个字符串,则返回0
  • 第一个字符串小于第二个字符串,则返回小于0的数字
  • 那么如何判断两个字符串?比较两个字符串中对应位置上字符ASCII码值的大小。

模拟实现

https://i-blog.csdnimg.cn/direct/e07cd27180fe499bb942bc072cba87b2.png

16.7 strncpy,strncat,strncmp

加一个n啥意思

通俗的解释就是多一个参数int num,表示拷贝几个字符或追加几个字符比较几个字符,而非全部拷贝完追加完比较完

strncpyhttps://i-blog.csdnimg.cn/direct/160308dae6dc48a0ba2b9cbf3e0d8e17.png

拷贝num个字符从源字符串到⽬标空间

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

strncathttps://i-blog.csdnimg.cn/direct/d245fa01a6ed44d18224003bc1380d56.png

将source指向字符串的前num个字符追加到destination指向的字符串末尾,再追加⼀个 \0 字符

如果source 指向的字符串的⻓度⼩于num的时候,只会将字符串中到\0 的内容追加到destination指向的字符串末尾

strncpy

https://i-blog.csdnimg.cn/direct/35de5e1a25b44b0199a9c3092c77252c.png

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

16.8 strstr

这个有点意思,为字符串中的字符串查找

https://i-blog.csdnimg.cn/direct/08d889f347cb4b6db3e38c3b52fd18ad.png

函数返回字符串str2在str1中第一次出现的地方

模拟实现

https://i-blog.csdnimg.cn/direct/f50283b0da5c46db979e297349ab29c8.png

拓展:字符串查找:KMP算法

16.9 strtok

https://i-blog.csdnimg.cn/direct/8fa349b9a590458386fc3b652e9bb332.png

第一个参数指向一个包含分隔符的字符串str,第二个参数sep指向的是储存分隔符集合的字符串

strtok函数找到str中的下⼀个标记,并将其⽤ \0 结尾,返回⼀个指向这个标记的指针。(注:

strtok函数会改变被操作的字符串,所以被strtok函数切分的字符串⼀般都是临时拷贝的内容并且

可修改。)

  • strtok函数的第一个参数不为NULL
  • 函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置
  • strtok函数的第一个参数为NULL,函数将在同一个字符串中被保存的位置开始,查找下一个标记
  • 如果字符串中不存在更多的标记,则返回NULL指针。

举个🌰

https://i-blog.csdnimg.cn/direct/76048c325437490bbd8d2ca93a283c19.png

16.10 strerror

可用于返回参数部分错误码对应的错误信息字符串的地址

不同语言以及C语言标准库中都规定了错误码,一般放在erron.h这个头文件中

C语言程序启动时会有一个全局变量errno来记录程序的错误码,初始值是0,表示没有错误

出现某种错误时就会将对应的错误码存放在errno中

单看错误码我们很难理解是什么意思,strerror就可以将错误对应的错误信息字符串的地址返回

下面我们来看一下具体的代码

https://i-blog.csdnimg.cn/direct/fa0b81abec7f40cd91ac9137aa39d163.png

https://i-blog.csdnimg.cn/direct/4bf2d8b1f7db478c98171e3efc9d7442.png

我们下面再来介绍一个函数perror

就是直接打印错误信息,省去了printf的使用

https://i-blog.csdnimg.cn/direct/7f587718291e4cdeb8146c050763acbe.png

https://i-blog.csdnimg.cn/direct/fb090c52987547808c3baca2a379d6a4.png

perror在双引号内可加入自定义信息,系统会自动加入冒号和空格,在打印错误信息

也可以什么都不写,直接打印


好了今天的学习内容就到这里啦,谢谢你的陪伴,我是潼心,下次再见如果这篇文章对你有帮助的话。请务必给主播一个一键三连,球球了,这对主播很重要https://i-blog.csdnimg.cn/direct/898a54b542a846db99d911dd5e05fb98.gif​ 

博主主页: