#include
#include
#include
#include
一、strlen 返回字符串的长度,不包含末尾的'\0'
int my_strlen(const char*str)
{
const char* temp = str;
while (*temp)
{
temp++;
}
return (temp - str);
}
二、my_strcmp(const char*str1,const char*str2),比较两个字符串的大小,实际上根据ASCII码表比较的,str1>str2返回1;str1=str2返回0,str1
int my_strcmp(const char*str1,const char*str2)
{
assert((str1 != NULL) && (str2 != NULL));
int ret = 0;
while (!(ret = *(unsigned char*)str1 - *(unsigned char*)str2) && *str1)
{
str1++;
str2++;
}
if (ret < 0)
{
return -1;
}
if (ret > 0)
{
return 1;
}
return 0;
}
三、strchr(const char*src,char dest),在src中找到第一次出现字符dset的位置。
const char* my_strchr(const char*src,char dest)
{
assert(src != NULL);
const char *m = NULL;
while (*src)
{
if (*src == dest)
{
m = src;
break;
}
src++;
}
return m;
}
四、strcat(char*dst,const char*src),拼接字符串,会覆盖dst末尾的'\0'
char* my_strcat(char*dst,const char*src)
{
assert((src != NULL) && (dst != NULL));
char* temp = dst;
while (*temp)
{
temp++;
}
while (*temp++ = *src++);
return dst;
}
五、strstr(const char*src,const char*dst),判断str1是否包含str2,包含返回str1中开始包含str2的位置,不包含返回空。
const char*my_strstr(const char*src,const char*dst)
{
assert((src != NULL) && (dst != NULL));
while (*src)
{
const char*temp1 = src;
const char*temp2 = dst;
const char*res = NULL;
if (*src == *dst)
{
res = temp1;
while (*temp1 && *temp2 && (*temp1++ == *temp2++));
if (*temp2 == '\0')
{
return res;
}
}
src++;
}
return NULL;
}
六、strcpy(char*dst,const char*src),将字符串src中的内容拷贝到dst中,注意操作的字符串不能重叠
char*my_strcpy(char*dst,const char*src)
{
assert((src != NULL) && (dst != NULL));
char*res = dst;
while (*dst++ = *src++);
return res;
}
七、strlwr(char*str)和strupr(char*str),将字符串中的大写字母改成小写,或者将小写字母改成大写。
char *my_strlwr(char*str)
{
assert(str != NULL);
char*temp = str;
while (*temp)
{
if (*temp > 'A' && *temp < 'Z')
{
*temp += 0x20;
}
temp++;
}
return str;
}
char *my_strupr(char*str)
{
assert(str != NULL);
char*temp = str;
while (*temp)
{
if (*temp > 'a' && *temp < 'z')
{
*temp -= 0x20;
}
temp++;
}
return str;
}