memcpy和memmove 的使用

memcpy是不考虑两个内存串是否有重叠的情况,而memmove是考虑的,也就是使用这个函数,我们就不用担心复制后的内存是否有误,而memcpy可能会被覆盖!

这里是一个在网络上的例子

区别:两个函数都是进行n字节内存内容的拷贝,入口参数和返回参数也都一样,可是这两个函数在内部实现上是有一定区别的,这主要是因为dest内存区域和src内存区域可能有一下四种不同的情况,注意count的影响:

从图中可以看出,src的内存区域和dest的内存区域相对位置和重叠关系有四种情况,memcpy没有考虑重叠的情况,而memmove考虑到了全部情况,因此memcpy函数的时候可能出现意向不到的结果。

 

这两个函数的实现:

void* mymemcpy(void* dest, void* source, size_t count)

{

       char *ret = (char *)dest;

       char *dest_t = ret;

       char *source_t = (char *)source;

       

       while (count--){

           *dest_t++ = *source_t++;

        }  

return ret;

}      

 

void *my_memmove(void *dst,const void *src,int count)

{

   char *ret;

   char *dst_t;

   char *src_t;

  

   ret = (char *)dst;

 

   if ((unsigned char*)dst <= (unsigned char*)src

|| (unsigned char *)dst >= ((unsigned char *)src + count))

   {

         dst_t = (char *)dst;

      src_t = (char *)src;

     

      while (count--)

      {

         *dst_t++ = *src_t++;

      }

   }else{

     dst_t = (char *)dst + count - 1;

     src_t = (char *)src + count - 1;

     while (count--)

      {

        *dst_t-- = *src_t--;

      }

   }

 

   return(ret);

 

}

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值