【C语言】字符函数和字符串函数

文章目录

字符分类函数

C语言中有一系列的函数是专门做字符分类的,也就是一个字符是属于什么类型的字符的。

这些函数的使用都需要包含一个头文件是 <ctype.h>

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

c 复制代码
int islower ( int c );

islower 是能够判断参数部分的c是否是小写字母的。

通过返回值来说明是否是小写字母,如果是小写字母就返回非0的整数,如果不是小写字母,则返回0。

使用代码演示:写一个代码,将字符串中的小写字母转大写,其他字符不变。

c 复制代码
#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;
}

字符转换函数

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

c 复制代码
int tolower ( int c ); //将参数传进去的大写字母转小写
int toupper ( int c ); //将参数传进去的小写字母转大写

上面的代码,我们将小写转大写,是-32完成的效果,有了转换函数,就可以直接使用 toupper函数。

c 复制代码
#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;
}

strlen的使用和模拟实现

计算字符串个数

c 复制代码
size_t strlen ( const char * str );

标准规定:

• 字符串以 '\0' 作为结束标志,strlen函数返回的是在字符串中 '\0' 前面出现的字符个数(不包含 '\0' )。

• 参数指向的字符串必须要以 '\0' 结束。

• 注意函数的返回值为size_t,是无符号的.(重点)

strlen的模拟实现:

strcpy的使用和模拟实现

字符串拷贝

c 复制代码
char* strcpy(char * destination, const char * source );

标准规定:

• 源字符串必须以 '\0' 结束。

• 会将源字符串中的 '\0' 拷贝到目标空间。

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

• 目标空间必须可变。

注意:不要将一个字符拷贝到常量字符串中,因为常量字符串不能被修改,程序会直接崩溃。

例如:

c 复制代码
char arr[4]="abc";
const char* p="qwertt";//加const更严谨,不加下面两个操作也是错误的
*p='w';//也是错误的
strcpy(p,arr);

strcpy的模拟实现:

strcat的使用和模拟实现

字符串追加

c 复制代码
char * strcat ( char * destination, const char * source );

标准规定:

• 源字符串必须以 '\0' 结束。

• 目标字符串中也得有 \0 ,否则没办法知道追加从哪里开始。

• 目标空间必须有足够的大,能容纳下源字符串的内容。

• 目标空间必须可修改。

• 尽量不要用strcat自己给自己追加,可以用strncat

strcat的模拟实现:

strcmp的使用和模拟实现

字符串比较

c 复制代码
int strcmp ( const char * str1, const char * str2 );

标准规定:

◦ 第一个字符串大于第二个字符串,则返回大于0的数字

◦ 第一个字符串等于第二个字符串,则返回0

◦ 第一个字符串小于第二个字符串,则返回小于0的数字

◦ 比较字符串的大小是比较两个字符串中对应位置上字符ASCII码值的大小。

strcmp的模拟实现:

小总结

strcpy(字符串拷贝),strcat(字符串追加),strcmp(字符串比较)是长度不受限制的字符串函数,一定程度上不安全。

strncpy函数的使用

c 复制代码
char * strncpy ( char * destination, const char * source, size_t num );

• 拷贝num个字符从source字符串到目标空间destination( 如果source字符串的长度不小于num不包括\0)。

• 如果source字符串的长度小于num,则拷贝完source字符串之后,在destination的后边追加\0,直到num个。

strncat函数的使用

c 复制代码
char * strncat ( char * destination, const char * source, size_t num );

• 将 source 的前 num 个字符附加到 destination,外加一个终止\0 字符。

• 如果 source 中 字符串的长度小于 num,则把 source中的字符串全部都追加过去。

strncmp函数的使用

c 复制代码
int strncmp ( const char * str1, const char * str2, size_t num );

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

strstr的使用和模拟实现

在字符串中查找另一个字符串

c 复制代码
const char * strstr ( const char * str1, const char * str2 );
      char * strstr (       char * str1, const char * str2 );

strstr的模拟实现:

strtok函数的使用

c 复制代码
char * strtok ( char * str, const char * sep);

• sep参数指向一个字符串,定义了用作分隔符的字符集合

• 第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标记。

• strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。(注:strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容并且可修改。)

• strtok函数的第一个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置。

• strtok函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标记。

• 如果字符串中不存在更多的标记,则返回 NULL 指针。

strerror函数的使用

c 复制代码
 char * strerror ( int errnum );

strerror函数可以把参数部分错误码对应的错误信息的字符串地址返回来。

在不同的系统和C语言标准库的实现中都规定了一些错误码,一般是放在 errno.h 这个头文件中说明的,C语言程序启动的时候就会使用一个全面的变量errno来记录程序的当前错误码,只不过程序启动的时候errno是0,表示没有错误,当我们在使用标准库中的函数的时候发生了某种错误,就会讲对应的错误码,存放在errno中,而一个错误码的数字是整数很难理解是什么意思,所以每一个错误码都是有对应的错误信息的。strerror函数就可以将错误对应的错误信息字符串的地址返回.

也可以了解一下perror函数,perror函数相当于一次将上述代码中的第9行完成了,直接将错误信息打印出来。

相关推荐
SomeB1oody13 分钟前
【Rust自学】10.6. 生命周期 Pt.2:生命周期的语法与例子
开发语言·后端·rust
数据小爬虫@18 分钟前
利用Java爬虫获取店铺所有商品:技术实践与应用指南
java·开发语言·爬虫
郭wes代码43 分钟前
Python安装(新手详细版)
开发语言·python
悟道茶一杯1 小时前
服务器开发 的泛型(Generics)基础知识
开发语言·后端·golang
zeijiershuai1 小时前
Java jdk8新特性:Stream 流
java·开发语言
YOULANSHENGMENG1 小时前
linux上使用cmake编译的方法
开发语言·c++
学计算机的睿智大学生2 小时前
关于python的数据分析与应用
开发语言·python·数据分析
晚安~~2 小时前
共享充电宝系统|Java|SSM|VUE| 前后端分离
java·开发语言·tomcat·maven
找了一圈尾巴2 小时前
Wend看源码-Java-Arrays 工具集学习
java·开发语言·学习
HelloZheQ2 小时前
Java与AI:构建智能应用的强大组合
java·开发语言·人工智能