C语言中必须掌握的字符串处理函数_第1页
C语言中必须掌握的字符串处理函数_第2页
C语言中必须掌握的字符串处理函数_第3页
C语言中必须掌握的字符串处理函数_第4页
C语言中必须掌握的字符串处理函数_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

那些你不太熟悉的字符串处理函数函数集合(全部包含在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 #include int main() char *s1=i aove; char *s2=i hate; int i=strcoll(s1,s2); int j=strcmp(s1,s2); printf(i=%d,j=%dn,i,j); return 0;Strxfrm()Strxfrm是一个字符串转换的函数,叫字符串s2转换后,保存到s1。这种转换根据lc_collate进行。当区域选项是“POSIX”或者“C”时,函数和strncpy一样。返回被转换的字符数(不包括结束的空字符)例子:#include #include int main() char s1100=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 #include 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;Strrchr()Strrchr寻找字符c在字符串s中最后一次出现的位置,终止符被认为是串的一部分。函数返回找到的字符的指针,如果没有,则返回空指针。#include #include 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;Strcspn()Strcspn计算s1指向的字符串中完全不是由s2字符串中的字符组成的最大初始段的长度。也就是说从头开始对比与s2串的字符后都不相同的连续字符的个数#include #include int main() char *s1=abcdefghijklmn abc abcd; char *s2=bc; int i=strcspn(s1,s2); printf(i=%dn,i); return 0;Strspn()Strspn计算s1指向的字符串完全由s2指向的字符串中的字符组成的最大初始段的长度。也就是说s1从头开始比,如果说第一个字符都不在s2中,则返回0,如果在,则比较第二个字符,返回值+1,依次比较,直到找到不同的为止;例子#include #include int main() char *s1=abcdefghijklmn abc abcd; char *s2=bc; int i=strspn(s1,s2); printf(i=%dn,i); return 0;#include #include int main() char *s1=abcdefghijklmn abc abcd; char *s2=abc; int i=strspn(s1,s2); printf(i=%dn,i); return 0;Strpbrk()Strpbrk()确定s2字符串中的任意字符在s1指向的字符串中首次出现的位置,返回该字符的指针,如果s1中没有s2中的任意字符,则返回空指针。#include #include int main() char *s1=abcdefghijklmn abc abcd; char *s2=kji; char* i=strpbrk(s1,s2); printf(第%d个,字符为:%cn,i-s1+1,*i); return 0;Strstr()Strstr返回一个字符指针,确定s1字符串中第一次出现s2字符串中的字符序列(必须是字符一样,顺序一样)的位置。如果没有找到该串,则返回空指针,如果s2长度为0,则返回s1.#include #include int main() char *s1=abcdefghijklmn abc abcd; char *s2=ghi; char* str=strstr(s1,s2); if(str=NULL) printf(nulln); else printf(%c,*str); return 0;Strtok()Strtok()以s2字符串为界,对s1字符串进行切割,从s1的头部开始对s1进行查找,一旦找到与s2字符串中的任意字符的相同的字符,则在该位置截断,s1的搜索位置会被静态变量记录下来,如果想从截断部分在进行一次截断查询,则需要将s1设置为NULL再执行该函数一次。这里要注意第一个字符串变量需要是一个可以改变的变量。#include #include int main(

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论