字符串函数(2)<C语言>

杨树与晨光 2024-08-02 17:35:02 阅读 78

前言

        快一周没更博客了,最近有点忙,今天闲下来了,还是不行,继续干,书接上回继续介绍字符串函数:strncpy()、strncat()、strcmp()、strtok()使用、strstr()使用以及模拟实现、strerror()使用。


strncpy()、strncat()、strncmp()

        这几个函数看着很眼熟,用法确实和前文的函数类似,不同的是多出了一个n。

strncpy()

        函数参数及其返回类型:

<code>char* strncpy(char* destination , const char* source , size_t num);

//返回值是目的字符串的起始地址

作用:

从源字符串中拷贝num个字符串到目的字符串中。

注意点:

①如果num大于源字符长度,在拷贝完源字符串后,在目标字符串中追加\0,直到num个。

②如果num小于源字符长度,在拷贝完指定字符串后,不会在目标字符串中追加\0

使用举例:

 strncat()

        函数参数及其返回类型:

<code>char* strncat(char* destination , const char* source , size_t num);

//返回值是目的字符串的起始地址

作用:

从源字符串中追加前num个字符串到目的字符串中,再追加个\0。

注意点:

①如果num大于源字符长度,只会将源字符串中到\0的字符串追加到目的字符串末尾。

②相较于strcat()函数,strncat()可实现自追加(先用strlen()函数求出字符串长度,再追加),原因也很简单,strncat()每次追加完毕会自动追加一个\0。

使用举例:

  strncmp()

        函数参数及其返回类型:

<code>int strncat(const char* str1, const char* str2 , size_t num);

//返回值是大于:大于0的数、等于:0、小于:小于0的数

作用:

比较str1与str2前num个字符

注意点:

使用举例:


 strtok()使用

        函数参数及其返回类型:

<code>char* strtok(char* str, const char* sep );

//返回值是指向找到以sep中的字符分隔的字符串的首地址,如果没找到返回NULL

作用:

找到第一次以sep字符串中的字符分隔的字符串的首地址

注意点:

①sep参数中定义了分隔字符串的集合,也就是说可以为多个分隔字符且可以无序

②当找到第一个以sep中字符分隔的字符串时,将分隔字符以\0替代(strtok()函数会改变源字符,所以一般会使用一个临时变量来接收,不改变源字符)

③strtok()函数具有记忆性(含有static关键字),所以当多次调用strtok()函数时,可将多个字段打印出来

④如果找不到以sep字符串中的字符分隔的字符串,就返回NULL

⑤strtok()函数第一个参数为NULL时,函数将在同一个字符保存的位置找下一个字段

使用举例:

//strtok()函数举例

#include<string.h>

int main() {

char str[20] = "192.91.89.7";//以“.”分隔的字符串

char* sep = ".";//分隔字符(可以为多个)

char* ret = NULL;

for (ret = strtok(str, sep); ret != NULL;ret=strtok(NULL,sep))

//初始化表达式只执行一次,取出第一个字段:ret = strtok(str, sep)

//条件表达式用于判断是否为NULL,为NULL则找不到了:ret != NULL

//更新表达式用于查找下一个字段,第一个参数为NULL时,会从上一次分隔位置查找:ret=strtok(NULL,sep)

printf("%s\n", ret);

return 0;

}

运行结果:


 strstr()使用以及模拟实现

      函数参数及其返回类型:

<code>char* strstr(const char* str1, const char* str2 );

//返回值是在str1中第一次出现str2字符串的首地址,如果没找到返回NULL

作用:

在str1中找str2字符串首次出现的位置

使用举例:

 模拟实现:

<code>#include<assert.h>

char* my_strstr(const char* str1, const char* str2) {

assert(str1 && str2);

const char* s1 = NULL;

const char* s2 = NULL;

const char* cur = str1;//cur直接指向str1

while (*cur) {

s1 = cur;//s1指向cur

s2 = str2;//s2变量用来指向str2

while (*s1 && *s2 && *s1 == *s2) {

//当s1和s2不为\0时继续找:*s1 && *s2

//满足条件找下一对字符:*s1 == *s2

s1++;

s2++;

}

if (!*s2) {//取反操作判断是否为\0,为\0说明s2对应到最后一个字符,跳出循环了

return cur;

}

cur++;

//cur自增,当一次不满足时,使指向cur的s1跳到下一个字符继续匹配

}

return NULL;

//指向str1的cur自增到str1的最后一个字符,还没匹配成功,说明找不到了,返回NULL

}

//strstr()函数模拟实现

int main() {

char str2[100] = "ABC";

char str1[100] = "HJKANUABCENNS";

char* str;

str = my_strstr(str1, str2);

printf("%s", str);

return 0;

}

运行结果:


 strerror()

       函数参数及其返回类型:

<code>char* strerror(int errornum);

//返回值是整型数字errornum对应的错误码信息首地址

作用:

strerror()函数可以把参数部分对应的错误码返回

注意点:

简单来说,在C语言编译器上规定了一些错误码(如栈溢出:strack overflew),一般存放在error.h头文件中,当C语言程序启动时,会使用全局变量errno来记录当前错误码的地址。

errno是一个全局变量用来存放错误码。

使用举例:

#include<string.h>

int main() {

int i;

for (i = 0; i < 10; i++) {

printf("%s\n", strerror(i));

//打印前10条错误码,其中错误码0为无错

}

return 0;

}

运行结果:

 值得注意的是使用perror()函数可以直接将当前错误码打印出来(括号内为提示信息,可不传参)



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。