strtok
char * strtok ( char * str, const char * sep )
sep参数是个字符串,定义了用作分隔符的字符集合
第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标
记。
strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。(注:
strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容
并且可修改。)
strtok函数的第一个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串
中的位置。
strtok函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标
记。
如果字符串中不存在更多的标记,则返回 NULL 指针
我们这里先来个简单代码说明一下:arr数组里面只有“ . "这一个字符,那么我们第一个参数就指定了一个”. ",并且在strtok函数中标记了这个字符,把他变成了“\0" (看buf[3]),并且有保存的记忆,下次执行从被保存的位置开始
![](https://i-blog.csdnimg.cn/blog_migrate/0d5392af8e0e5b63792634ea29a9cc21.png)
strerror
char * strerror ( int errnum )
![](https://i-blog.csdnimg.cn/blog_migrate/fcaeef67180eca553414b1db06c1647b.png)
我们在下面这个图可知:C语言的库函数在执行失败时,都会有一个错误码,该函数返回一个指向错误字符串的指针,该错误字符串描述了错误 errnum。
这里我们说明一下:我们在c语言中每次发生错误时,错误码都会存入到errno中,而下次错误码出现时会覆盖上一次的错误码
![](https://i-blog.csdnimg.cn/blog_migrate/dd44f1182f0dae2ca32f117eb912824e.png)
字符分类函数:
函数 | 如果他的参数符合下列条件就返回真 |
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 | 任何可打印字符,包括图形字符和空白字符 |
memcpy
void * memcpy ( void * destination, const void * source, size_t num )
函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。
这个函数在遇到 '\0' 的时候并不会停下来。
如果source和destination有任何的重叠,复制的结果都是未定义的
代码如下:注意我们这个num是字节数
![](https://i-blog.csdnimg.cn/blog_migrate/d262007e1c3cade0fcb3829c8a343f5b.png)
memmove
void * memmove ( void * destination, const void * source, size_t num )
和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
如果源空间和目标空间出现重叠,就得使用memmove函数处理
![](https://i-blog.csdnimg.cn/blog_migrate/35333cee16c31b32da0c754824a81b42.png)
我们这个代码是从后到前移动,是src在dest前面所以我们必须从5到1移动,否则就会导致代码打印出来的不是我们所想要的
![](https://i-blog.csdnimg.cn/blog_migrate/27c01c3dc231e3f8e3a1b35b2bfb5d17.png)
以上就是我们的字符函数和字符串函数的介绍;完结撒花,喜欢的话请三连支持一下哦!!!