1、strcat()

此函数原型为 char *strcat(char *dest, const char *src).
功能为连接两个字符串,把src连接到dest后面;返回dest地址
实现如下
  1. char *my_strcat(char *strDest,const char *strSrc) //将源字符串加const,表明其为输入参数
  2. {
  3. char *addrStr=strDest;
  4.  
  5. assert(strDest!=NULL && strSrc!=NULL); //对源地址和目的地址加非0断言
  6. //若使用while(*strDest++),则会出错,指向'\0'之后,会出现strDest++,则指向了个'\0'的下一个位置,
  7. while(*strDest !='\0')
  8. {
  9. strDest++; //循环体内的++可以使指向字符串结束标志'\0'
  10. }
  11. while((*strDest++ = *strSrc++)!='\0');
  12.  
  13. return addrStr;
  14. }

  效果:

    str1[10]="hello";

    str2[10]=" world";

    strcat(str1,str2);

    printf("%s\n",str1);  //显示:    hello world         sizeof(str1)==12

2、strcmp()

此函数的函数原型为 int strcmp(const char *str1, const char *str2).
功能为比较两个字符串。
当str1指向的字符串大于str2指向的字符串时,返回正数。
当str1指向的字符串等于str2指向的字符串时,返回0。
当str1指向的字符串小于str2指向的字符串时,返回负数。
实现如下:
  1. int my_strcmp(const char *str1,const char *str2)
  2. {
  3. /*不可用while(*str1++==*str2++)来比较,当不相等时仍会执行一次++,
  4. return返回的比较值实际上是下一个字符。应将++放到循环体中进行。*/
  5. while(*str1 == *str2)
  6. {
  7. if(*str1 == '\0')
  8. return 0;
  9.  
  10. str1++;
  11. str2++;
  12. }
  13. return *str1 - *str2;
  14. }

效果: 

   printf("%d\n",my_strcmp("aaaa","aaa1"));  //返回正数

   printf("%d\n",my_strcmp("aaaa","aaaa"));  //返回0

   printf("%d\n",my_strcmp("baaa","akkkkkkk"));  //注意:这里返回正数  [只比较首次2个不相同的字符大小]

   printf("%d\n",my_strcmp("akkkkkkk","faaa"));  //注意:这里返回负数   [只比较首次2个不相同的字符大小]  

3、strcpy()

此函数原型为 char *strcpy(char* dest, const char *src)
功能为拷贝字符串内容到目的串,把src所指向的内容拷贝到dest
实现如下
  1. char *my_strcpy(char *strDest,const char *strSrc)
  2. {
  3. char *addrStr = strDest;
  4.  
  5. assert((strDest!=NULL) && (strSrc!=NULL)); //对源地址和目的地址加非0断言
  6. while((*strDest++ = *strSrc) != '\0');
  7.  
  8. return addrStr;
  9. }

  效果: 

    str1[10]="1234";

    str2[10]=" ab";

    printf("%s\n",strcpy(str1,str2));  //显示: ab   (而不是ab34)

4、strlen()

此函数原型为unsigned in strlen(const char *str)

功能为返回字符串str的长度(不包括'\0')。

实现如下:

  1. //自己编写的strlen函数
  2. int my_strlen(const char *str)
  3. {
  4. int length=0;
  5.  
  6. while(*str!='\0')
  7. {
  8. str++;
  9. length++;
  10. }
  11.  
  12. return(length);
  13. }

  效果: 

    printf("%d\n",sizeof("ab"));  //显示: 3     

    printf("%d\n",my_strlen("ab"));  //显示: 2

  

5、strchr()  strrchr()

char *strchr(char *str, char c)

功能为查找str中首次出现c的位置(指针),如有有,则返回出现位置,否则返回NULL。实现如下:

  1. char *my_strchr(char *str,const char c)
  2. {
  3. while (*str!=c && str!='\0')
  4. {
  5. str++;
  6. }
  7.  
  8. return ((*str==c)?str:NULL);
  9. }

  效果:

    char arr1[3]="ab";  

    printf("%p\n",arr1);  //显示: 0xbfc8b5c4
    printf("%p\n",my_strchr(arr1,'b'));  //显示: 0xbfc8b5c5

    

char *strrchr(char *str, char c)

功能为查找str中最后一次出现c的位置,如有有,则返回出现位置,否则返回NULL。实现如下:

  1. char *my_strrchr(char *str,char c)
  2. {
  3. char *p = str + strlen(str); //p指向字符串最后一个字符'\0'
  4.  
  5. while(*p!=c && p!=str)
  6. {
  7. p--;
  8. }
  9.  
  10. return(*p==c?p:NULL);
  11. }

  效果:

    char arr1[3]="abb";  

    printf("%p\n",arr1);  //显示: 0xbfc8b5c4
    printf("%p\n",my_strrchr(arr1,'b'));  //显示: 0xbfc8b5c5

    printf("%p\n",my_strrchr(arr1,'c'));  //显示: NULL

6、strcspn()  strspn()

strcspn

原型:size_t strcspn(const char *pstr, const char *strCharset)

MSDN解释为:在字符串pstr中搜寻strCharsret中所出现的字符,返回strCharset中出现的第一个字符在pstr中的出现位置。简单的说,若strcspn返回的数值为n,则代表字符串strCharsrt开头连续有n个字符不包含在pstr内的字符。

实现十分巧妙,在http://blog.csdn.net/chenyu2202863/article/details/5293941

原型size_t strspn(const char *pstr, const char *strCharset)

功能:返回后面字符串中第一个不在前者出现的下表。

7、strdup()

此函数原型为char *strdup(const char *str)
功能为: strdup()会先用maolloc()配置与参数str 字符串相同的空间大小,然后将参数str 字符串的内容复制到该内存地址,然后把该地址返回。若失败,返回NULL。要注意,返回的指针指向的内存在堆中,所以要手动释放。
函数实现
  1. char *strdup(const char *str)
  2. {
  3. char *p=NULL;
  4. if(str&&(p=(char*)malloc(strlen(str)+1)))
  5. strcpy(p,str);
  6. return p;
  7. }

  效果:

   char a[] = "strdup";

   char *b;

   b = strdup(a);

      printf("b[]=\"%s\"\n", b);  //显示: b[]="strdup"

8、strrev()

此函数的原型为char *strrev(char *str)
功能为反转字符串,返回字符串指针。
函数实现:

  1. char *my_strrev(char *str)
  2. {
  3. char temp;
  4. char *start = str;
  5. char *end = str+strlen(str)-1;
  6.  
  7. if(str==NULL)
  8. return(NULL);
  9.  
  10. while(start<end)
  11. {
  12. temp = *start;
  13. *start = *end;
  14. *end = temp;
  15.  
  16. start++;
  17. end--;
  18. }
  19.  
  20. return(str);
  21. }

  效果:

    char arr1[20]="abcdef";  

    printf("%s\n",my_strrev(arr1)); //显示fedcba

9、strstr()

函数原型为char *strstr(const char str1, const char *str2)
功能为查找字符串str2在str1中出现的位置,找到则返回位置,否则返回NULL。
函数实现:
  1. char *strstr(const char str1, const char *str2)
  2. {
  3. int length1=strlen(str1);
  4. int length2=strlen(str2);
  5. while(length1>=length2)
  6. {
  7. length1--;
  8. if(!strncpy(str1,str2,length2))//比较前n个字符串,类似strcpy
  9. return str1;
  10. str1++;
  11. }
  12. return NULL;
  13. }

自己编写的str操作函数的更多相关文章

  1. PHP常用的文件操作函数集锦

    以下是个人总结的PHP文件操作函数.当然,这只是部分,还有很多,我没有列出来. 一 .解析路径: 1 获得文件名:basename();给出一个包含有指向一个文件的全路径的字符串,本函数返回基本的文件 ...

  2. 嵌入式 python之str操作

    1.字符串的对齐方式:①:center(int[,str])>>> string = 'Fishhat'>>> string.center(55)'         ...

  3. LoadRunner中常用的字符串操作函数

    LoadRunner中常用的字符串操作函数有:                strcpy(destination_string, source_string);               strc ...

  4. dedecms功能性函数封装(XSS过滤、编码、浏览器XSS hack、字符操作函数)

    dedecms虽然有诸多漏洞,但不可否认确实是一个很不错的内容管理系统(cms),其他也不乏很多功能实用性的函数,以下就部分列举,持续更新,不作过多说明.使用时需部分修改,你懂的 1.XSS过滤. f ...

  5. JavaScript中常见的字符串操作函数及用法

    JavaScript中常见的字符串操作函数及用法 最近几次参加前端实习生招聘的笔试,发现很多笔试题都会考到字符串的处理,比方说去哪儿网笔试题.淘宝的笔试题等.如果你经常参加笔试或者也是一个过来人,相信 ...

  6. js原生的url操作函数,及使用方法。(附:下边还有jquery对url里的中文解码函数)

    js原生的url操作函数,完善的. /*****************************/ /* 动态修改url */ /*****************************/ var ...

  7. Effective C++ 之 Item 5:了解C++默默编写并调用哪些函数

    Effective C++ chapter 2. 构造 / 析构 / 赋值运算 (Constructors, Destructors, and Assignment Operators) Item 5 ...

  8. Linux 多线程应用中如何编写安全的信号处理函数

    http://blog.163.com/he_junwei/blog/static/1979376462014021105242552/ http://www.ibm.com/developerwor ...

  9. Runtime机制之结构体及操作函数

    一.动态语言 Objective-C语言是一门动态语言,它将很多静态语言在编译和链接时期做的事放到了运行时来处理.这种动态语言的优势在于:具有灵活性,比如:消息转发,方法交换等.它有一个运行时系统Ob ...

随机推荐

  1. noip模拟赛 旅行

    分析:一个贪心的想法是每次找到根的点权和最大的点进行操作,关键是怎么维护.每次找最大值,修改后会对这条链上每个点的子树上的点造成影响,可以用线段树来维护.找最大值就是区间求最大值嘛,对子树进行操作利用 ...

  2. springData Jpa 快速入门

    前言: 数据持久化的操作,一般都要由我们自己一步步的去编程实现,mybatis通过我们编写xml实现,hibernate也要配置对应的xml然后通过创建session执行crud操作.那么有没有这样一 ...

  3. SPFA 算法

    百度百科: http://baike.baidu.com/link?url=O0QvxbOY8SVBjrIl6nF6EvMHSslgcEIxfXSoty5SbkA7QjbWZjTWARzwTQsKKb ...

  4. Combinations(带for循环的DFS)

    Given two integers n and k, return all possible combinations of k numbers out of 1 ... n. For exampl ...

  5. Remove Duplicates from Sorted Array(参考)

    Given a sorted array, remove the duplicates in place such that each element appear only once and ret ...

  6. LTTNG 使用

    http://lttng.org/docs/#doc-channel http://www.cnblogs.com/suncoolcat/p/3366045.html http://blog.csdn ...

  7. MongoDB小结26 - 地理空间索引

    现在有一种查询变得越来越流行(尤其是移动设备):找到离当前位置最近的N个场所. MongoDB专为平面坐标查询做了专门的索引,称为地理空间索引. 同样需要用ensureIndex创建,不过,参数是两个 ...

  8. ubuntu12.04+cuda6.0+opencv2.4.9

    更新了cuda之后,opencv的gpu模块又要重新编译了,这个地方有一个疑问,我对cuda6.0装了两次,第一次装好之后,没有配一个bumblebee,重装了cuda6.0之后,发现原来编译的ope ...

  9. myloader恢复mysql数据库演示样例

     mydumper是针对mysql数据库备份的一个轻量级第三方的开源工具.备份方式为逻辑备份.它支持多线程.备份速度远高于原生态的mysqldump以及众多优异特性.与其相配套的恢复工具则是mylo ...

  10. MySQL Study之--MySQL压力測试工具mysqlslap

    MySQL Study之--MySQL压力測试工具mysqlslap 一.Mysqlslap介绍     mysqlslap是MySQL5.1之后自带的benchmark基准測试工具,类似Apache ...