1.strlen(计算字符串的长度)(1)非递归int my_strlen(const char *str)
{
char *p = str;
int count = 0;
while (*p != '\0')
{
count++;
p++;
}
return count;
}
(2)递归
int my_strlen(char *str)
{
if (*str == '\0')
return 0;
else
return 1 + my_strlen(str + 1);
}
2.strcpy(把从src地址开始且含有'\0'结束符的字符串复制到以dest开始的地址空间,返回值的类型为char*)
char* my_strcpy(char* dest, const char *src)
{
assert(dest);
assert(src);
char *ret = dest;
while (*src != '\0')
{
*dest = *src;
++dest;
++src;
}
*dest = '\0';
return ret;
}
3.strcat(字符串连接函数)
char* my_strcat(char *dest, const char* src)
{
assert(dest);
assert(src);
char *ret = dest;
while (*dest != '\0')
{
++dest;
}
while (*src != '\0')
{
*dest = *src;
++dest;
++src;
}
*dest = '\0';
return ret;
}
4.strstr (strstr(str1, str2)判断str2是否是str1的子串,如果是返回str2在str1中的位置,不是返回空)
char* my_strstr(const char* str1, const char* str2)
{
assert(str1);
assert(str2);
char* cp = str1;
char* s1 = NULL;
char* substr = str2;
if (*str2 == '\0')
{
return NULL;
}
while (*cp != '\0')
{
s1 = cp;
substr = str2;
while (*s1 && *substr && (*s1 == *substr))
{
s1++;
substr++;
}
if (*substr == '\0')
{
return cp;
}
cp++;
}
}
5.strcmp(两个字符串自左向右逐个字符相比(按ASCII值大小相比较),直到出现不同的字符或遇'\0'为止)
int my_strcmp(const char* src, const char* dest)
{
int ret = 0;
assert(src);
assert(dest);
while ((ret = *(unsigned char*)src - *(unsigned char*)dest) == 0 && *dest != '\0')
{
src++;
dest++;
}
if (ret > 0)
ret = 1;
else if (ret < 0)
ret = -1;
return ret;
}