模拟实现strlen,strcpy,strcat,strstr,strcmp,memcpy,memmove

【strlen】
返回字符串的长度,不包括‘\0’

//变量计数器
int my_strlen(const char* str)
{
    int count = 0;
    while (*str)//遍历一遍字符串,走一个,计数器加一
    {
        count++;
        str++;
    }
    return count;
}
//不创建变量计数器(递归)
int my_strlen(const char* str)
{
    if (*str == '\0')
        return 0;
    else
        return 1 + my_strlen(str + 1);//递归往今走一步,加一
}
//指针
int my_strlen(char *s)
{
    char *p = s;
    while (*p != '\0')//也是遍历字符串
        p++;
    return p - s;
}

【strcpy】
不会拷贝’\0’

char* my_strcpy(char* dest, const char* src)
{
    char* ret = dest;
    assert(dest);
    assert(src);
    while ((*dest++ = *src++))//两个都是先解以用再++。到了'\0',赋值之后判断结束循环
    {
        ;
    }
    return ret;
}

【strcat】

char* my_strcat(char* dest, const char* src)
{
    char* ret = dest;
    assert(dest);
    assert(src);
    while (*dest)//到'\0'
    {
        dest++;
    }
    while ((*dest++ = *src++))
    {
        ;
    }
    return ret;
}

【strstr】
看是不是子串,是返回其位置

char* my_strstr(const char* str1, const char* str2)
{
    assert(str1);
    assert(str2);
    char *cp = (char*)str1;
    char *substr = (char *)str2;
    char *s1 = NULL;
    if (*str2 == '\0')
        return NULL;
    while (*cp)
    {
        s1 = cp;
        substr = str2;
        while (*s1&&*substr && (*s1 == *substr))
        {
            s1++;
            substr++;
        }
        if (*substr == '\0')
            return cp;
        cp++;
    }
}

【strcmp】

int my_strcmp(const char* src, const char* dst)
{
    int ret = 0;
    while (!(ret = *(unsigned char *)src - *(unsigned char*)dst) && *dst)
    {
        ++src;
        ++dst;
    }
    if (ret < 0)
        ret = -1;
    else if (ret>0)
        ret = 1;
    return(ret);
}

【memmove】
内存copy

void* memcpy(void *dst, const void *src, size_t count)
{
    void *ret = dst;
    while (count--)
    {
        *(char *)dst = *(char *)src;
        dst = (char *)dst + 1;
        src = (char *)src + 1;
    }
    return(ret);
}

【memmove】

void *memmove(void *dst, const void *src, size_t count)
{
    void *ret = dst;
    if (dst <= src || (char *)dst >= ((char *)src + count))
    {
        while (count--)
        {
            *(char *)dst = *(char *)src;
            dst = (char *)dst + 1;
            src = (char *)src + 1;
        }
    }
    else
    {
        dst = (char *)dst - 1;
        src = (char *)src - 1;
        while (count--)
        {
            *(char *)dst = *(char *)src;
            dst = (char *)dst - 1;
            src = (char *)src - 1;
        }
    }
    return(ret);
}

如果有不对的地方,可以评论告诉我,望指导!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值