C语言中必须掌握的字符串处理函数.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C语言中必须掌握的字符串处理函数

那些你不太熟悉的字符串处理函数函数集合(全部包含在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码排序,但是对于设置了lc_collate语言环境的情况下,则根据设置的环境比较大小,譬如,汉字根据拼音排序。例子:#include stdio.h#include string.hint 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;}Strxfrm()Strxfrm是一个字符串转换的函数,叫字符串s2转换后,保存到s1。这种转换根据lc_collate进行。当区域选项是“POSIX”或者“C”时,函数和strncpy一样。返回被转换的字符数(不包括结束的空字符)例子:#include stdio.h#include string.hint 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;}Strchr()Strchr是一个寻找字符c在字符串s中第一次出现的位置,终止用的空字符被认为是返回串的一部分。返回定位字符的指针,如果没有,则返回空指针。#include stdio.h#include string.hint main(){ char *s1=i am a student; char c=m; char *des=strchr(s1,c); printf(是第%d个,字符为:%c,des-s1+1,*des); return 0;}Strrchr()Strrchr寻找字符c在字符串s中最后一次出现的位置,终止符被认为是串的一部分。函数返回找到的字符的指针,如果没有,则返回空指针。#include stdio.h#include string.hint main(){ char *s1=i am a student; char c=t; char *des=strrchr(s1,c); printf(是第%d个,字符为:%c,des-s1+1,*des); return 0;}Strcspn()Strcspn计算s1指向的字符串中完全不是由s2字符串中的字符组成的最大初始段的长度。也就是说从头开始对比与s2串的字符后都不相同的连续字符的个数#include stdio.h#include string.hint main(){ char *s1=abcdefghijklmn abc abcd; char *s2=bc; int i=strcspn(s1,s2); printf(i=%d\n,i); return 0;}Strspn()Strspn计算s1指向的字符串完全由s2指向的字符串中的字符组成的最大初始段的长度。也就是说s1从头开始比,如果说第一个字符都不在s2中,则返回0,如果在,则比较第二个字符,返回值+1,依次比较,直到找到不同的为止;例子#include stdio.h#include string.hint main(){ char *s1=abcdefghijklmn abc abcd; char *s2=bc; int i=strspn(s1,s2); printf(i=

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档