收藏 分销(赏)

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

上传人:天**** 文档编号:3107290 上传时间:2024-06-18 格式:DOC 页数:7 大小:95.50KB
下载 相关 举报
C语言中必须掌握的字符串处理函数.doc_第1页
第1页 / 共7页
C语言中必须掌握的字符串处理函数.doc_第2页
第2页 / 共7页
C语言中必须掌握的字符串处理函数.doc_第3页
第3页 / 共7页
C语言中必须掌握的字符串处理函数.doc_第4页
第4页 / 共7页
C语言中必须掌握的字符串处理函数.doc_第5页
第5页 / 共7页
点击查看更多>>
资源描述

1、那些你不太熟悉的字符串处理函数函数集合(全部包含在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);Cha

2、r * 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 a

3、ove; 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,s

4、2,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中最后一次出现的位置,

5、终止符被认为是串的一部分。函数返回找到的字符的指针,如果没有,则返回空指针。#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=abcdefg

6、hijklmn 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); print

7、f(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=kj

8、i; 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 p

9、rintf(%c,*str); return 0;Strtok()Strtok()以s2字符串为界,对s1字符串进行切割,从s1的头部开始对s1进行查找,一旦找到与s2字符串中的任意字符的相同的字符,则在该位置截断,s1的搜索位置会被静态变量记录下来,如果想从截断部分在进行一次截断查询,则需要将s1设置为NULL再执行该函数一次。这里要注意第一个字符串变量需要是一个可以改变的变量。#include #include int main() char s1100=abcdefghijklmn abc abcd; char *s2=bdk; char* str=strtok(s1,s2); while(str) printf(s=%sn,str); str=strtok(NULL,s2); return 0;

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 通信科技 > 开发语言

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服