//Linux字符串函数集:

头文件:string.h

  •   函数名: strstr
  •   函数原型:extern char *strstr(char *str1, char *str2);
  •   功能:找出str2字符串在str1字符串中第一次出现的位置(不包括str2的串结束符)。
  •   返回值:返回该位置的指针,如找不到,返回空指针。
  1. 包含文件:string.h
  2.   函数名: strstr
  3.   函数原型:extern char *strstr(char *str1, char *str2);
  4.   功能:找出str2字符串在str1字符串中第一次出现的位置(不包括str2的串结束符)。
  5.   返回值:返回该位置的指针,如找不到,返回空指针。
  1. 原型:extern char *strchr(const char *s,char c);
  2.   const char *strchr(const char* _Str,int _Val)
  3.   char *strchr(char* _Str,int _Ch)
  4.   头文件:#include <string.h>
  5.   功能:查找字符串s中首次出现字符c的位置
  6.   说明:返回首次出现c的位置的指针,如果s中不存在c则返回NULL。
  7.   返回值:Returns the address of the first occurrence of the character in the string if successful, or NULL otherwise
  1. 原型:extern char *strchr(const char *s,char c);
  2.   const char *strchr(const char* _Str,int _Val)
  3.   char *strchr(char* _Str,int _Ch)
  4.   头文件:#include <string.h>
  5.   功能:查找字符串s中首次出现字符c的位置
  6.   说明:返回首次出现c的位置的指针,如果s中不存在c则返回NULL
  7.   返回值:Returns the address of the first occurrence of the character in the string if successful, or NULL otherwise
  1. C语言函数strrchr
  2. 函数简介
  3.   函数名称: strrchr
  4.   函数原型:char *strrchr(char *str, char c);
  5.   所属库: string.h
  6.   函数功能:查找一个字符c在另一个字符串str中末次出现的位置(也就是从str的右侧开始查找字符c首次出现的位置),并返回从字符串中的这个位置起,一直到字符串结束的所有字符。如果未能找到指定字符,那么函数将返回NULL。
  1. C语言函数strrchr
  2.  
  3. 函数简介
  4.   函数名称: strrchr
  5.   函数原型:char *strrchr(char *str, char c);
  6.   所属库: string.h
  7.   函数功能:查找一个字符c在另一个字符串str中末次出现的位置(也就是从str的右侧开始查找字符c首次出现的位置),并返回从字符串中的这个位置起,一直到字符串结束的所有字符。如果未能找到指定字符,那么函数将返回NULL
  1. strcmp
  2. 函数简介
  3.   原型:extern int strcmp(const char *s1,const char * s2);
  4.   用法:#include <string.h>
  5.   功能:比较字符串s1和s2。
  6.   一般形式:strcmp(字符串1,字符串2)
  7.   说明:
  8.   当s1<s2时,返回值<0
  9.   当s1=s2时,返回值=0
  10.   当s1>s2时,返回值>0
  11.   即:两个字符串自左向右逐个字符相比(按ASCII值大小相比较),直到出现不同的字符或遇'\0'为止。如:
  12.   "A"<"B" "a">"A" "computer">"compare"
  13.   特别注意:strcmp(const char *s1,const char * s2)这里面只能比较字符串,不能比较数字等其他形式的参数。
  1. strcmp
  2. 函数简介
  3.  
  4.   原型:extern int strcmp(const char *s1,const char * s2);
  5.   用法:#include <string.h>
  6.   功能:比较字符串s1s2
  7.   一般形式:strcmp(字符串1,字符串2)
  8.   说明:
  9.   s1<s2时,返回值<0
  10.   s1=s2时,返回值=0
  11.   s1>s2时,返回值>0
  12.   即:两个字符串自左向右逐个字符相比(按ASCII值大小相比较),直到出现不同的字符或遇'\0'为止。如:
  13.   "A"<"B" "a">"A" "computer">"compare"
  14.   特别注意:strcmp(const char *s1,const char * s2)这里面只能比较字符串,不能比较数字等其他形式的参数。
  1. strncmp
  2.   函数名: strncmp
  3.   功 能: 串比较
  4.   用 法: int strncmp(char *str1, char *str2, int maxlen);
  5.   说明:此函数功能即比较字符串str1和str2的前maxlen个字符。如果前maxlen字节完全相等,返回值就=0;在前maxlen字节比较过程中,如果出现str1[n]与str2[n]不等,则返回(str1[n]-str2[n])。
  1. strncmp
  2.  
  3.   函数名: strncmp
  4.    能: 串比较
  5.    法: int strncmp(char *str1, char *str2, int maxlen);
  6.   说明:此函数功能即比较字符串str1str2的前maxlen个字符。如果前maxlen字节完全相等,返回值就=0;在前maxlen字节比较过程中,如果出现str1[n]与str2[n]不等,则返回(str1[n]-str2[n])。
  1. strlwr
  2.   原型:extern char *strlwr(char *s);
  3.   用法:#include <string.h>
  4.   功能:将字符串s转换为小写形式
  5.   说明:只转换s中出现的大写字母,不改变其它字符。返回指向s的指针。
  6.   注意事项:在Linux的编译器中,有可能会编译不通过。
  1. strlwr
  2.  
  3.   原型:extern char *strlwr(char *s);
  4.   用法:#include <string.h>
  5.   功能:将字符串s转换为小写形式
  6.   说明:只转换s中出现的大写字母,不改变其它字符。返回指向s的指针。
  7.   注意事项:在Linux的编译器中,有可能会编译不通过。
  1. strcat
  2. C函数
  3. 原型
  4.   extern char *strcat(char *dest,char *src);
  5. 用法
  6.   #include <string.h>
  7.   在C++中,则存在于<cstring>头文件中。
  8. 功能
  9.   把src所指字符串添加到dest结尾处(覆盖dest结尾处的'\0')并添加'\0'。
  10. 说明
  11.   src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
  12.   返回指向dest的指针。
  1. strcat
  2. C函数
  3.  
  4. 原型
  5.   extern char *strcat(char *dest,char *src);
  6. 用法
  7.   #include <string.h>
  8.   C++中,则存在于<cstring>头文件中。
  9. 功能
  10.   src所指字符串添加到dest结尾处(覆盖dest结尾处的'\0')并添加'\0'
  11. 说明
  12.   srcdest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
  13.   返回指向dest的指针。
  1. 函数名:   strncpy
  2. 功     能:   串拷贝
  3. 用     法:   char   *strncpy(char   *destin,   char   *source,   int   maxlen);
  4. memcpy
  5. 功     能:   从源source中拷贝n个字节到目标destin中
  6. 一个考字符串,一个拷贝内存内容
  7. strncpy
  8. 原型:extern   char   *strncpy(char   *dest,   char   *src,   int   n);
  9. 用法:#include   <string.h>
  10. 功能:把src所指由NULL结束的字符串的前n个字节复制到dest所指的数组中。
  11. 说明:
  12. 如果src的前n个字节不含NULL字符,则结果不会以NULL字符结束。
  13. 如果src的长度小于n个字节,则以NULL填充dest直到复制完n个字节。
  14. src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
  15. 返回指向dest的指针。
  16. 举例:
  17. //   strncpy.c
  18. #include   <syslib.h>
  19. #include   <string.h>
  20. main()
  21. {
  22. char   *s= "Golden   Global   View ";
  23. char   *d= "Hello,   GGV   Programmers ";
  24. char   *p=strdup(s);
  25. clrscr();
  26. textmode(0x00);     //   enable   6   lines   mode
  27. strncpy(d,s,strlen(s));
  28. printf( "%s\n ",d);
  29. strncpy(p,s,strlen(d));
  30. printf( "%s ",p);
  31. getchar();
  32. return   0;
  33. }
  34. ------------------------------
  1. 函数名: strncpy
  2. 能: 串拷贝
  3. 法: char *strncpy(char *destin, char *source, int maxlen);
  4. memcpy
  5. 能: 从源source中拷贝n个字节到目标destin
  6. 一个考字符串,一个拷贝内存内容
  7.  
  8. strncpy
  9. 原型:extern char *strncpy(char *dest, char *src, int n);
  10.  
  11. 用法:#include <string.h>
  12.  
  13. 功能:把src所指由NULL结束的字符串的前n个字节复制到dest所指的数组中。
  14.  
  15. 说明:
  16. 如果src的前n个字节不含NULL字符,则结果不会以NULL字符结束。
  17. 如果src的长度小于n个字节,则以NULL填充dest直到复制完n个字节。
  18. srcdest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
  19. 返回指向dest的指针。
  20.  
  21. 举例:
  22. // strncpy.c
  23.  
  24. #include <syslib.h>
  25. #include <string.h>
  26. main()
  27. {
  28. char *s= "Golden Global View ";
  29. char *d= "Hello, GGV Programmers ";
  30. char *p=strdup(s);
  31.  
  32. clrscr();
  33. textmode(0x00); // enable 6 lines mode
  34.  
  35. strncpy(d,s,strlen(s));
  36. printf( "%s\n ",d);
  37.  
  38. strncpy(p,s,strlen(d));
  39. printf( "%s ",p);
  40.  
  41. getchar();
  42. return 0;
  43. }
  44. ------------------------------
  1. memcpy
  2. 原型:extern   void   *memcpy(void   *dest,   void   *src,   unsigned   int   count);
  3. 用法:#include   <string.h>
  4. 功能:由src所指内存区域复制count个字节到dest所指内存区域。
  5. 说明:src和dest所指内存区域不能重叠,函数返回指向dest的指针。
  6. 举例:
  7. //   memcpy.c
  8. #include   <syslib.h>
  9. #include   <string.h>
  10. main()
  11. {
  12. char   *s= "Golden   Global   View ";
  13. char   d[20];
  14. clrscr();
  15. memcpy(d,s,strlen(s));
  16. d[strlen(s)]=0;
  17. printf( "%s ",d);
  18. getchar();
  19. return   0;
  20. }
  1. memcpy
  2. 原型:extern void *memcpy(void *dest, void *src, unsigned int count);
  3. 用法:#include <string.h>
  4.  
  5. 功能:由src所指内存区域复制count个字节到dest所指内存区域。
  6.  
  7. 说明:srcdest所指内存区域不能重叠,函数返回指向dest的指针。
  8.  
  9. 举例:
  10. // memcpy.c
  11.  
  12. #include <syslib.h>
  13. #include <string.h>
  14. main()
  15. {
  16. char *s= "Golden Global View ";
  17. char d[20];
  18.  
  19. clrscr();
  20.  
  21. memcpy(d,s,strlen(s));
  22. d[strlen(s)]=0;
  23. printf( "%s ",d);
  24. getchar();
  25. return 0;
  26. }
  1. strcpy
  2. 原型:extern   char   *strcpy(char   *dest,char   *src);
  3. 用法:#include   <string.h>
  4. 功能:把src所指由NULL结束的字符串复制到dest所指的数组中。
  5. 说明:src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
  6. 返回指向dest的指针。
  7. 举例:
  8. //   strcpy.c
  9. #include   <syslib.h>
  10. #include   <string.h>
  11. main()
  12. {
  13. char   *s= "Golden   Global   View ";
  14. char   d[20];
  15. clrscr();
  16. strcpy(d,s);
  17. printf( "%s ",d);
  18. getchar();
  19. return   0;
  20. }
  21. -----------------------------------------------
  22. strcpy只是复制字符串,但不限制复制的数量。很容易造成缓冲溢出。
  23. strncpy要安全一些。
  24. memcpy也可以用来在内存中复制数据,由于字符串是以零结尾的,所以对于在数据中包含零的数据只能用memcpy。
  25. 性能上它们不一定有多大差别。

Linux字符串函数集的更多相关文章

  1. C语言通用双向循环链表操作函数集

    说明 相比Linux内核链表宿主结构可有多个链表结构的优点,本函数集侧重封装性和易用性,而灵活性和效率有所降低.     可基于该函数集方便地构造栈或队列集.     本函数集暂未考虑并发保护. 一  ...

  2. 使用Word API打开Word文档 ASP.NET编程中常用到的27个函数集

    使用Word API(非Openxml)打开Word文档简单示例(必须安装Word) 首先需要引入参照Microsoft.Office.Interop.Word 代码示例如下: public void ...

  3. JS判断字符串是否为空、过滤空格、查找字符串位置等函数集

    这是一个由网上收集的JS代码段,用于判断指定字符串是否为空,过滤字符串中某字符两边的空格.查找指定字符串开始的位置.使用IsFloat函数判断一 个字符串是否由数字(int or long or fl ...

  4. C语言字符串操作函数集

    1)字符串操作 strcpy(p, p1) 复制字符串 strncpy(p, p1, n) 复制指定长度字符串 strcat(p, p1) 附加字符串 strncat(p, p1, n) 附加指定长度 ...

  5. VBA 字符串处理函数集

    转自:http://blog.csdn.net/jyh_jack/article/details/2315345 mid(字符串,从第几个开始,长度)  在[字符串]中[从第几个开始]取出[长度个字符 ...

  6. Linux学习-函式库管理

    动态与静态函式库 首先我们要知道的是,函式库的类型有哪些?依据函式库被使用的类型而分为两大类,分别是静态 (Static) 与动态 (Dynamic) 函式库两类. 静态函式库的特色: 扩展名:(扩展 ...

  7. XSLT函数集合:数值函数、字符串函、节点集函数和布尔函数

    任何的编程语言或者是SQL语句都有内置的函数或方法,而强大灵活的xslt技术也是如此.熟练掌握XSLT的常用函数的用法,XSLT的应用将变得如此轻松,你会发现XSLT比想象中还要牛!以下是xslt数值 ...

  8. makefile 函数集

    1 if 函数 语法 $(if CONDITION,THEN-PART[,ELSE-PART]) 功能 第一个参数"CONDITION",在函数执行时忽略其前导和结尾空字符,如果包 ...

  9. Linux字符串截取和处理命令 cut、printf、awk、sed、sort、wc

    1. cut [选项] 文件名 -f  列号 #提取第几列(分隔符默认为\t) -d  分隔符 #指定分隔符 例如:cut -f 2 a.txt #截取文件a.txt内容的第二列(列号从1开始) cu ...

随机推荐

  1. Linq/EF/lambda Group by/Order by 多个字段详细用法

    1)单个字段Group by: //a.Key类型与a.Province字段类型一样  .GroupBy(a => a.Province).Select(a => a.Key).ToLis ...

  2. string.Format 日期格式化

    String.Format日期的格式化例子: DateTime dt = DateTime.Now;//2010年10月4日 17点05分 string str = ""; //s ...

  3. 使用Flexible 实现手淘H5 页面的终端适配学习

    Amfe阿里无线前端团队双11技术连载之际,一个实战案例来展示多终端适配. Device metrics 1.0 mdpi 2.0 xhdpi 3.0xxhdpi(iphone 6 plus) 手淘h ...

  4. 优秀的开发者 vs. 差的开发者

    优秀的开发者是一个艺术家,一个享受创作过程的工匠.差的开发者只将自己当作负责产生代码的码农. 优秀的开发者了解客户的问题.差的开发者只了解手头的技术问题.优秀的开发者会不断努力去理解"为什么 ...

  5. RTF格式文件浅析

    ps:这两天在分析从微软的word复制一个绕排环绕的表格到openoffice的writer中去的bug,需要了解RTF... RTF是Rich TextFormat的缩写,意即多文本格式.这是一种类 ...

  6. 同一张表不同SESSION相互持有对方记录引发的死锁

    锁产生的原因:如果有两个会话,每个会话都持有另一个会话想要的资源,此时就会发生死锁. 同一张表不同SESSION持有不同记录 SQL> create table t1(id int); Tabl ...

  7. 【转】onPrepareOptionsMenu 和onCreateOptionsMenu 的区别

    原文网址:http://blog.csdn.net/allenjy123/article/details/7467084 @Override public boolean onCreateOption ...

  8. hihoCoder 1389 Sewage Treatment 【二分+网络流+优化】 (ACM-ICPC国际大学生程序设计竞赛北京赛区(2016)网络赛)

    #1389 : Sewage Treatment 时间限制:2000ms 单点时限:2000ms 内存限制:256MB 描述 After years of suffering, people coul ...

  9. unicode编码、字符的转换和得到汉字的区位码

    一:unicode编码.字符的转换截图 二:unicode编码.字符的转换代码 using System; using System.Collections.Generic; using System ...

  10. 动态规划——F 最大矩阵和

    Given a two-dimensional array of positive and negative integers, a sub-rectangle is any contiguous s ...