欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 创投人物 > C语言常用字符串处理函数

C语言常用字符串处理函数

2025/2/23 15:23:40 来源:https://blog.csdn.net/asd12342153/article/details/145298292  浏览:    关键词:C语言常用字符串处理函数

头文件:#include <string.h>

strlen

size_t strlen( char *str );
功能:函数返回一个整数值,表示给定字符串的长度(不包括结束符'\0')

strcat

char *strcat( char *str1, const char *str2 );
功能:函数将字符串str2 连接到str1的末端,并返回指针str1.

#include <stdio.h>
#include <string.h>int main() {char str1[50] = "Hello";char str2[] = " World!";strcat(str1, str2);printf("%s\n", str1); // 输出: Hello World!return 0;
}

strcpy

char *strcpy( char *destc, const char *src );
功能:函数从源字符串src的第一个字符开始,逐个字符地复制到目标字符串dest中,直到遇到源字符串的终止符'\0'。复制完成后,目标字符串dest也以'\0'结尾。

#include <stdio.h>
#include <string.h>int main() {char src[] = "Hello, World!";char dest[50]; // 确保目标数组足够大以容纳源字符串strcpy(dest, src);printf("Source: %s\n", src); //输出 Hello, World!printf("Destination: %s\n", dest);// Hello, World!return 0;
}

现象

strncpy

char *strncpy( char *to, const char *from, size_t count );
功能:将字符串from 中至多count个字符复制到字符串to中。如果字符串from 的长度小于count,其余部分用'\0'填补。返回处理完成的字符串。

#include <stdio.h>
#include <string.h>int main() {char src[] = "Hello, World!";char dest[50]; // 确保目标数组足够大以容纳源字符串strncpy(dest, src,5);printf("Source: %s\n", src); //输出 Hello, World!printf("Destination: %s\n", dest);return 0;
}

现象

strcmp

常用于比较两个字符串是否相等。
int strcmp( const char *str1, const char *str2 );
功能:比较字符串str1 and str2, 返回值如下:
返回值                 解释 
<0             str1 is less than str2 
=0             str1 is equal to str2 
>0             str1 is greater than str2 

#include <stdio.h>
#include <string.h>int main() {char str1[] = "Hello";char str2[] = "World";int result = strcmp(str1, str2);if (result == 0) {printf("字符串相等。\n");} else if (result < 0) {printf("str1 小于 str2。\n");} else {printf("str1 大于 str2。\n");}return 0;
}

现象:
比较了两个字符串"Hello"和"World",由于"H"的ASCII值小于"W"的ASCII值,因此strcmp函数返回负数,程序输出"str1 小于 str2"。

strncmp

int strncmp( const char *str1, const char *str2, size_t count );
功能:比较字符串str1 和 str2中至多count个字符。

#include <stdio.h>
#include <string.h>int main() {char str1[] = "HelloABC";char str2[] = "HelloDEF";int result = strncmp(str1, str2,5);if (result == 0) {printf("前5个字符相等\n");} else if (result < 0 || result >0) {printf("前5个字符不相等\n");}return 0;
}

现象:

strstr

char *strstr( const char *str1, const char *str2 );
功能:函数返回一个指针,它指向字符串str2 首次出现于字符串str1中的位置,如果没有找到,返回NULL。

#include <stdio.h>
#include <string.h>int main() {const char *str1 = "Hello, World!";const char *str2 = "Wo";char *result = strstr(str1, str2);if (result) {printf("Found : %s\n", result);} else {printf("Not found.\n");}return 0;
}

现象:

strcspn

常用于定位删除字符串 '\n' 换行符
size_t strcspn( const char *str1, const char *str2 );
功能:函数返回str1 开头连续n个字符都不含字符串str2内字符的字符数。

实例一:

#include <stdio.h>
#include <string.h>int main() {char str1[] = "Hello";char str2[] = "!@#$";size_t result = strcspn(str1, str2);printf("strcspn_result: %zu\n", result);return 0;
}

现象:
strcspn函数计算字符串"Hello"中从起始位置开始连续不包含字符串"!@#"中字符的跨度。由于"Hello"这5个字符都不属于"!@#"中的字符,因此result返回5

实例二:

#include <stdio.h>
#include <string.h>int main() {char str1[] = "Hello\n";size_t result = strcspn(str1, "\n");str1[result] = '\0';printf("strcspn_result: %zu\n", result);printf("str1:%s",str1);return 0;
}

现象:

atoi

头文件:#include <stdlib.h>
int atoi( const char *str );

功能:将字符串str转换成一个整数并返回结果。参数str 以数字开头,当函数从str 中读到非数字字符则结束转换并将结果返回。

#include <stdio.h>
#include <stdlib.h>int main() {int n1,n2;const char *str1 = "123abc";const char *str2 = "abc123";n1 = atoi(str1);n2 = atoi(str2);printf("n1:%d\r\n",n1);printf("n2:%d\r\n",n2);return 0;
}

现象:

memset

void *memset( void *buffer, int ch, size_t count );
功能: 函数拷贝ch 到buffer 从头开始的count 个字符里, 并返回buffer指针。 memset() 可以应用在将一段内存初始化为某个值。

#include <stdio.h>
#include <string.h>#define CLEAR(x)  memset((x),0,sizeof(x))int main() {char str1[] = "Hello,world!";printf("str1:%s\r\n",str1);CLEAR(str1);printf("str1:%s\r\n",str1);return 0;
}

现象:

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词