大家好,这次的内容是讲解我对C语言部分库函数的初步理解,并且代码都以VS2022的C语言实现,若有错误,恳请读者大大们批评指正。
1.字符分类函数
C语言中有一系列的函数是专门做字符分类的,也就是一个字符是属于什么类型的字符的。这些函数的使用都需要包含头文件 ctype.h。
函数 | 若参数符合下列条件就返回真 |
iscntrl | 任何控制字符 |
isspace | 空白字符:空格 ' ',换页 '\f',换行 '\n',回车 '\r',制表符 '\t' 或者垂直制表符 '\v' |
isdigit | 十进制数字 0~9 |
isxdigit | 十六进制数字,包括所有十进制数字,小写字母 a~f,大写字母 A~F |
islower | 小写字母 a~z |
isupper | 大写字母 A~Z |
isalpha | 字母 a~z 或 A~Z |
isalnum | 字母或者数字,a~z,A~Z,0~9 |
ispunct | 标点符号,任何不属于数字或者字母的图形字符 (可打印) |
isgraph | 任何图形字符 |
isprint | 任何可打印字符,包括图形字符和空白字符 |
2.字符转换函数
C语言提供了两个字符转换函数 tolower 和 toupper ,头文件也为 ctype.h。
函数 | 功能 |
tolower | 将参数传进去的大写字母转小写 |
toupper | 将参数传进去的小写字母转大写 |
3.strlen的使用和模拟实现
strlen函数的使用:
1.字符串以 '\0' 作为结束标志,strlen函数返回字符串中 '\0' 前面出现的字符个数(不包含'\0')。
2.参数指向的字符串必须要以 '\0' 结束。
3.函数的返回值为 size_t,是无符号的。
4.strlen函数的使用需要包含头文件 string.h。
strlen函数的模拟实现:
cplusplus网站对strlen函数的详细解释https://legacy.cplusplus.com/reference/cstring/strlen/?kw=strlen
4.strcpy的使用和模拟实现
strcpy函数的使用:
1.将原字符串复制到目标数组中,包括终止 NULL( '\0' ) 字符(并在该点停止)。
2.原字符串必须以 '\0' 结束。
3.会将原字符串中的 '\0' 拷贝到目标空间。
4.目标空间必须足够大,以确保能存放原字符串。
5.目标空间必须可修改。
6.strcpy函数的使用需要包含头文件 string.h。
strcpy函数的模拟实现:
cplusplus网站对strcpy函数的详细解释https://legacy.cplusplus.com/reference/cstring/strcpy/?kw=strcpy
5.strcat的使用和模拟实现
strcat函数的使用:
1.将原字符串(source) 追加到目标字符串(destination) 。终止 NULL ( '\0' ) 字符在 destination 中被 source 的第一个字符覆盖,并且 source 末尾包含一个 NULL 字符,这个字符为新字符串的末尾。
2.原字符串必须以 '\0' 结束。
3.目标字符串中也得有 '\0' ,否则没办法知道追加从哪里开始。
4.目标空间需要能容下原字符串的内容。
5.目标空间必须可修改。
6.不能自己追加自己。
7.strcat函数的使用需要包含头文件 string.h。
![](https://img-blog.csdnimg.cn/direct/7214407e5f954b1d93e90e02bc39a73d.png)
strcat函数的模拟实现:
cplusplus网站对strcat函数的详细解释https://legacy.cplusplus.com/reference/cstring/strcat/?kw=strcat
6.strcmp的使用和模拟实现
strcmp函数的使用:
1.比较字符串的第一个字符,比较方法是字符对应的 ASCII码值。如果相等,会继续向后比较,直到字符不同或到达字符 '\0'。
2.标准规定:
第一个字符串大于第二个字符串,则返回大于0的数字。
第一个字符串等于第二个字符串,则返回0。
第一个字符串小于第二个字符串,则返回小于0的数字。
3.strcmp函数的使用需要包含头文件 string.h。
![](https://img-blog.csdnimg.cn/direct/ae456868b4704abaa01fcd7781726bf0.png)
strcmp函数的模拟实现:
cplusplus网站对strcmp函数的详细解释https://legacy.cplusplus.com/reference/cstring/strcmp/?kw=strcmp
![](https://img-blog.csdnimg.cn/direct/8686994997244b848a4c56239d4acd90.png)
7.strncpy的使用和模拟实现
strncpy函数的使用:
1.将原字符串前 num 个字符复制到目标中,如果原字符串的长度小于 num,则目标字符串用零填充,直到总共写入了 num 个字符。
2.strncpy函数的使用需要头文件 string.h。
strncpy函数的模拟实现:
cplusplus网站对strncpy函数的详细解释https://legacy.cplusplus.com/reference/cstring/strncpy/?kw=strncpy
8.strncat函数的使用和模拟实现
strncat函数的使用:
1.将 source 指向的字符串前 num 个字符追加到 destination 指向的字符串末尾,再追加一个 '\0' 字符。
2.如果 source 指向的字符串长度小于 num 的时候,只会将字符串中到 '\0' 的内容追加到 destination 指向的字符串末尾。
3.strncat函数的使用需要包含头文件 string.h。
![](https://img-blog.csdnimg.cn/direct/41321ca2f9a740c88d2df8a238887011.png)
strncat函数的模拟实现:
9.strncmp的使用
1.比较 str1 和 str2 的前 num 个字符,如果相等就继续往后比较,最多比较 num 个字符,如果提前发现不相等,则提前结束,大的字符所在的字符串大于另外一个。如果 num 个字符都相等,则返回0。
2.strncmp函数的使用需要包含头文件 string.h。
![](https://img-blog.csdnimg.cn/direct/5eb1b5b56a3840acb8926530dc60683a.png)
10.strstr的使用和模拟实现
strstr函数的使用:
1.返回字符串str2在字符串str1中第一次出现的指针(地址),没有则返回 NULL 指针。
2.字符串的比较匹配不包含 '\0' 字符,以 '\0' 作为结束标志。
3.strstr函数的使用需要包含头文件 string.h。
![](https://img-blog.csdnimg.cn/direct/97e31cd70aa5422181f8604467506cd7.png)
strstr函数的模拟实现:
cplusplus网站对strstr函数的详细解释https://legacy.cplusplus.com/reference/cstring/strstr/?kw=strstr
11.strtok的使用
cplusplus网站对strtok函数的详细解释https://legacy.cplusplus.com/reference/cstring/strtok/?kw=strtok
1.delimiters参数指向一个字符串,定义了用作分隔符的字符集合。
2.第一个参数指定一个字符串,它包含了0个或者多个由delimiters字符串中一个或者多个分隔符分割的标记。
3. strtok函数 找到 str 中的下一个标记,并将其用 '\0' 结尾,返回一个指向这个标记的指针。(注:strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容并且可修改)
4. strtok函数的第一个参数不为NULL, 函数将找到 str 中第一个标记,strtok函数将保存它在字符串中的位置。
5.strtok函数的第一个参数为 NULL, 函数将在同一个字符串中被保存的位置开始,查找下一个标记。
6.如果字符串中不存在更多的标记,则返回 NULL 指针。
7.strtok函数的使用需要包含头文件 string.h。
![](https://img-blog.csdnimg.cn/direct/64d4fb67ef6c4c8187bdc9e699f191be.png)
12.strerror的使用
1.strerror函数可以把参数部分错误码对应的错误信息的字符串地址返回来。
2.在不同的系统和C语⾔标准库的实现中都规定了⼀些错误码,⼀般是放在 errno.h 这个头⽂件中说明的。
3.C语⾔程序启动的时候就会使⽤⼀个全⾯的变量errno来记录程序的当前错误码,只不过程序启动的时候errno是0,表⽰没有错误。
4.当我们在使⽤标准库中的函数的时候发⽣了某种错误,就会讲对应的错误码,存放在errno中,⽽⼀个错误码的数字是整数很难理解是什么意思,所以每⼀个错误码都是有对应的错误信息的。
5.strerror函数就可以将错误对应的错误信息字符串的地址返回。
cplusplus网站对strerror函数的详细解释https://legacy.cplusplus.com/reference/cstring/strerror/?kw=strerror
![](https://img-blog.csdnimg.cn/direct/669560a99964441a907164348ce1e0ee.png)
13.memcpy的使用和模拟实现
memcpy函数的使用:
1.memcpy函数从 source 的位置开始向后复制 num 个字节的数据到 destination 指向的内存位置。
2.这个函数在遇到 '\0' 的时候并不会停下来。
3.如果 source 和 destination 有任何的重叠,复制的结果都是未定义的。
4.对于重叠的内存,交给memmove函数来处理。
5.memcpy函数的使用需要包含头文件 string.h。
memcpy函数的模拟实现:
cplusplus网站对memcpy函数的详细解释https://legacy.cplusplus.com/reference/cstring/memcpy/?kw=memcpy
14.memmove的使用和模拟实现
memmove函数的使用:
1.它与memcpy的差别就是memmove函数处理的原内存块和目标内存块是可以重叠的。
2.如果原空间和目标空间出现重叠,就得使用memmove函数处理。
![](https://img-blog.csdnimg.cn/direct/f55b04dfa930400995e13e6cee3649b6.png)
memmove函数的模拟实现:
cplusplus网站对memmove函数的详细解释https://legacy.cplusplus.com/reference/cstring/memmove/?kw=memmove
15.memset的使用
1.memset函数是用来设置内存的,将内存中的值以字节为单位设置成想要的内容。
2.memset函数的使用需要头文件 string.h。
16.memcmp的使用
cplusplus网站对memcmp函数的详细解释https://legacy.cplusplus.com/reference/cstring/memcmp/?kw=memcmp
1.memcmp函数比较从 ptr1 和 ptr2 指针指向的位置开始,向后的 num 个字节(一个字节一个字节的比较),如果它们都匹配,则返回零,如果它们不匹配,则返回一个与零不同的值,表示哪个值更大。
2.与 strcmp 不同,该函数在找到 NULL('\0') 字符后不会停止比较。
3.memcmp函数的使用需要包含头文件 string.h。
![](https://img-blog.csdnimg.cn/direct/632c234feacf4866800d53e8144aef83.png)
结语:
以上便是文章的所有内容了。
谢谢阅读