那些你不太熟悉的字符串处理函数
函数集合(全部包含在string.h头文件中)
Int strcoll(const char *s1, const char *s2);
Size_t 处理字符串的常用函数strxfrm(char *s1, const char *s2, size_t n);
Char *strchr(const char *s, int c);
Char *strrchr(const char *s, int c);
Size_t strcspn(const char *s1, const char *s2):
Size_t strspn(const char *s1, const char *s2):
Char * strpbrk(const char *s1, const char *s2):
Char *strstr(const char *s1, const char *s2);
Char *strtok(char *s1, const char *s2);
Strcoll()
Strcoll是一个比较两个字符串大小的函数,比较规则是LC_COLLATE;默认情况下和strcmp等 函数一样是根据ascii码排序,但是对于设置了厄_811ate语言环境的情况下,则根据设置的 环境比较大小,譬如,汉字根据拼音排序。
例子:
#include <stdio.h>
#include <string.h> int main()
char *s1="i aove";
char *s2="i hate";
int i=strcoll(s1,s2);
int j=strcmp(s1,s2);
printf("i=%d,j=%d\n",i,j);
return 0;
DI D:\Cod eBl ock&"\cod e\Etrte&t\ bin\D ebu g\E-trte&
Q—L J=-Zl
Process returned □ (0x0) QMQCution Tims 1□.009 s Press any key to continua.
Strxfrm()
Strxfrm是一个字符串转换的函数,叫字符串s2转换后,保存到s1。这种转换根据lc_collate 进行。当区域选项是“POSIX”或者“C”时,函数和strncpy 一样。返回被转换的字符数(不 包括结束的空字符) 例子:
#include <stdio.h>
#include <string.h> int main()
char s1[100]="i aove";
char *s2="i hate";
int i=strxfrm(s1,s2,99-strlen(s1));
printf("i=%d,s1= %s",i,s1);
return 0;
口 D;\CodeBlock&\cQde\strtest\bim\Debii
i=6. sl= ± hat。
Process resTurned 0 (0x0) e.xecution times : □. 011 m Frees any k^y 七口 匚DrrLinue.
Strchr()
Strchr是一个寻字符c在字符串s中第一次出现的位置,终止用的空字符被认为是返回串 的一部分。返回定位字符的指针,如果没有,则返回空指针。
#include <stdio.h>
#include <string.h>
int main()
(
char *s1="i am a student";
char c='m';
char *des=strchr(s1,c);
printf("是第%d 个,字符为:%c",des-s1+1,*des);
return 0;
)
J D:\Cod eB I m ks\c q d e\&trt est\bin\Debu gV&lrtest. exe
Process retiirned □ (0x0) execution TiniQ : □. 009 £ Press a.ny key L口 coRtinue.
Strrchr()
Strrchr寻字符c在字符串s中最后一次出现的位置,终止符被认为是串的一部分。函数返 回到的字符的指针,如果没有,则返回空指针。
#include <stdio.h>
#include <string.h>
int main()
char *s1="i am a student";
char c='t';
char *des=strrchr(s1,c);
printf("是第%d 个,字符为:%c",des-s1+1,*des);
return 0;
3 D:\CodeEiockiXcode\itrteit\bin\Debug\&
'foeess reTLLrned 0 (0^0^ 电:k。cut ion t ime : 0. 00S ■£
rass any key to eontinua.
Strcspn()
Strcspn计算s1指向的字符串中完全不是由s2字符串中的字符组成的最大初始段的长度。也 就是说从头开始对比与s2串的字符后都不相同的连续字符的个数
#include <stdio.h>
#include <string.h>
int main()
(
char *s1="abcdefghijklmn abc abcd";
char *s2="bc";
int i=strcspn(s1,s2);
printf("i=%d\n",i);
return 0;
Strspn()
Strspn计算si指向的字符串完全由s2指向的字符串中的字符组成的最大初始段的长度。也 就是说si从头开始比,如果说第一个字符都不在s2中,则返回0,如果在,则比较第二个 字符,返回值+1,依次比较,直到到不同的为止;
例子
#include <stdio.h>
#include <string.h> int main()
char *si="abcdefghijklmn abc abcd";
char *s2="bc";
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论