memcpy && memmove 的代码实现和区别

memcpy && memmove

两者的相同点:实现内存上的拷贝,都在<string.h>头文件中

  • memcpy:

函数原型:void *memcpy(void *dst, const void *src, size_t count)
函数功能:memcpy()函数从src内存中拷贝n个字节到dest内存区域,但是源和目的的内存区域不能重叠
返回值:memcpy()函数返回指向dest的指针。
代码实现:

void *My_memcpy(void *dest,const void *src,size_t n)
        {
            assert(dest != NULL && src != NULL && n >= 0);
            char *p = (char*)dest;
            char *q = (char*)src;
            while( n-- > 0 )
            {
                *p++=*q++;
                
            }
            return dest;
        }
  • memmove:

函数原型:void *memmove(void *dst, const void *src, size_t count)
函数功能: memmove() 函数从src内存中拷贝n个字节到dest内存区域,但是源和目的的内存可以重叠
函数返回值:memmove函数返回一个指向dest的指针。
代码实现:

void *My_memmove(void *dest,const void *src,size_t n)
          {
              assert(dest != NULL && src != NULL && n >= 0);
               char *p = (char*)dest;
               char *q = (char*)src;
               if(p>q)
               {
                     while( n-- > 0 )
                    {
                        *p++=*q++;
                
                    }
               }
               else
               {
                    char *p = (char*)dest+n-1;
                    char *q = (char*)src+n-1;
                    while( n -- >0)
                    {
                        *p -- = *q --;
                    }
               }
               return dest;
          }

两者的区别:

他们的作用都是在内存中拷贝,唯一的区别是,当内存发生局部重叠的时候,memmove保证拷贝的结果是正确的,memcpy不保证拷贝的结果的正确。
下图是两种情况:
在这里插入图片描述
第一种情况下,拷贝重叠的区域不会出现问题,内容均可以正确的被拷贝。
第二种情况下,问题出现在右边的两个字节,这两个字节的原来的内容首先就被覆盖了,而且没有保存。所以接下来拷贝的时候,拷贝的是已经被覆盖的内容,显然这是有问题的。

在memcpy实现第一种时,其拷贝结果不会出差错,情况如下:
在这里插入图片描述
第二种情况下,就会出现覆盖,从而产生拷贝结果出错(如下图)
在这里插入图片描述

memmove 在处理两种情况是不会出现错误:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值