1、strcat()
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 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 *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)
{
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 *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)
{
int length1=strlen(str1);
int length2=strlen(str2);
while(length1>=length2)
{
length1--;
if(!strncpy(str1,str2,length2))//比较前n个字符串,类似strcpy
return str1;
str1++;
}
return NULL;
}