自己编写的str操作函数

 

1、strcat()

此函数原型为 char *strcat(char *dest, const char *src).
功能为连接两个字符串,把src连接到dest后面;返回dest地址
实现如下
char *my_strcat(char *strDest,const char *strSrc) //将源字符串加const,表明其为输入参数
{
    char *addrStr=strDest;

    assert(strDest!=NULL && strSrc!=NULL); //对源地址和目的地址加非0断言
    //若使用while(*strDest++),则会出错,指向'\0'之后,会出现strDest++,则指向了个'\0'的下一个位置,
    while(*strDest !='\0') 
    {
        strDest++; //循环体内的++可以使指向字符串结束标志'\0'
    }
    while((*strDest++ = *strSrc++)!='\0');

    return addrStr; 
}

  效果:

    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指向的字符串时,返回负数。
实现如下:
int my_strcmp(const char *str1,const char *str2)
{
    /*不可用while(*str1++==*str2++)来比较,当不相等时仍会执行一次++,
    return返回的比较值实际上是下一个字符。应将++放到循环体中进行。*/
    while(*str1 == *str2)
    {
        if(*str1 == '\0')
            return 0;
         
		str1++;
		str2++;
    }
    return *str1 - *str2;
}

 效果: 

   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
实现如下
char *my_strcpy(char *strDest,const char *strSrc)
{
    char *addrStr = strDest;

    assert((strDest!=NULL) && (strSrc!=NULL)); //对源地址和目的地址加非0断言
    while((*strDest++ = *strSrc) != '\0');

    return addrStr;
}

  效果: 

    str1[10]="1234";

    str2[10]=" ab";

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

4、strlen()  

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

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

实现如下:

//自己编写的strlen函数
int my_strlen(const char  *str)
{
  int length=0;

  while(*str!='\0')
  {
    str++;
    length++;
  }

  return(length);
}   

  效果: 

    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。实现如下:

char *my_strchr(char *str,const char c)
{
	while (*str!=c && str!='\0')
	{
		str++;
	}

	return ((*str==c)?str:NULL);
}

  效果:

    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。实现如下:

char  *my_strrchr(char  *str,char c)
{
  char  *p = str + strlen(str); //p指向字符串最后一个字符'\0'
  
  while(*p!=c && p!=str)
  {
    p--;
  }

  return(*p==c?p:NULL);
} 

  效果:

    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。要注意,返回的指针指向的内存在堆中,所以要手动释放。
函数实现
char *strdup(const char *str)  
{  
    char *p=NULL;  
    if(str&&(p=(char*)malloc(strlen(str)+1)))  
        strcpy(p,str);  
    return p;  
}

  效果:

   char a[] = "strdup";

   char *b;

   b = strdup(a);

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

8、strrev()

此函数的原型为char *strrev(char *str)
功能为反转字符串,返回字符串指针。
函数实现:
 
char  *my_strrev(char *str)
{
  char  temp;
  char  *start = str;
  char  *end = str+strlen(str)-1;

  if(str==NULL)
    return(NULL);

  while(start<end)
  { 
    temp = *start;
    *start = *end;
    *end = temp;

    start++;
    end--;
  }    

  return(str);
}   

  效果:

    char arr1[20]="abcdef";  

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

9、strstr()

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

 

转载于:https://www.cnblogs.com/linuxAndMcu/p/7098317.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值