永恒的话题-段拷贝

虽然说段拷贝是5年前的事情了,但是还是被人问到吐血.

记得,上中专的时候,老师说过段拷贝.那时是使用si,di的.不过老师在上课的时候介绍的比较简单,就是通过看题目上的条件,如果数

据区域有交集,需要使用何种方式拷贝?

反着传!

怎么反呢?

如果,SRC>=DEST并且有交集的话,我们需要从数据区的低地址向高地址传递.

如果,DEST>SRC并且有交集的话,我们需要从数据区的高地址向低地址传递.

这样可以保证,数据的完整性.

void *memmove(void *dest, const void *src, size_t count)
{
    char *tmp;
    const char *s;

    if (dest <= src) {
        tmp = dest;
        s = src;
        while (count--)
            *tmp++ = *s++;
    } else {
        tmp = dest;
        tmp += count;
        s = src;
        s += count;
        while (count--)
            *--tmp = *--s;
    }
    return dest;
}


void *memcpy(void *dest, const void *src, size_t count)
{
    char *tmp = dest;
    const char *s = src;

    while (count--)
        *tmp++ = *s++;
    return dest;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值