详解memmove+模拟实现memmove

本文详细介绍了C语言中的内存拷贝函数memmove,特别强调了它与memcpy的区别在于处理重叠内存区域的能力。文章通过示例展示了memmove在不同重叠情况下的工作原理,并提供了一个模拟实现的代码片段。在示例中,通过调用自定义的my_memmove函数,演示了如何正确处理内存块重叠导致的数据复制问题。
摘要由CSDN通过智能技术生成

memmove -内存拷贝函数

void* memmove(void*destination ,const void* source,size_t num)

 

memmove和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的

如果源空间和目标空间出现重叠,就得使用memmove函数来处理

 

源空间和目标空间的重叠有3种情况:

1.dest<src

src->dest 从前(相对于src来讲)向后拷贝

 

2.src<dest<src+count

src->dest 从后向前拷贝

 

3.src<dest

从前向后/从后向前 均可

那就规定从后向前

 

模拟实现memmove

void* my_memmove(void* dest, const void* src, size_t num)

{

        void* ret = dest;

        assert(dest != NULL);

        assert(src != NULL);

        if (dest<src)

        {

               //前->后

               while (num--)

               {

                       *(char*)dest = *(char*)src;

                       ++(char*)dest;

                       ++(char*)src;

               }

        }

        else

        {

               //后->前

               while (num--)

               {

                       *((char*)dest + num) = *((char*)src + num);

               }

        }

        return ret;

}

int main()

{

        int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };

        int i = 0;

        my_memmove(arr + 2, arr, 20);

        for (i = 0; i < 10;i++)

        {

               printf("%d ", arr[i]);//1 2 1 2 3 4 5 8 9 10                                 

        }

        return 0;

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值