memcpy 与 memmove的区别

本文详细解析了C语言中的memcpy和memmove函数,阐述了它们在处理内存拷贝时的区别,尤其是在源区域与目标区域有重叠情况下的表现。memcpy在非重叠区域下效率较高,而memmove则能正确处理所有情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

memcpy 和 memmove 都是C语言中的库函数,在头文件string.h中,作用是拷贝一定长度的内存的内容,原型分别如下: 
void *memcpy(void *dst, const void *src, size_t count); 
void *memmove(void *dst, const void *src, size_t count);  


当源区域(src,src+n)与目标区域(dst,dst+n)没有重叠的时候,二者一样
当源区域(src,src+n)与目标区域(dst,dst+n)有重叠的时候,memmove能保证结果正确,memcpy不能
原因:
memmove在拷贝时,先把src中要拷贝的内容 逐字节(用char访问) 在一个buffer中存起来,再 逐字节 拷贝到 dst中
memcpy在拷贝时,没有中间转化的buffer,直接逐个把src中的内容拷到dst中,其中重叠的部分会被覆盖

关于memmove的实现:

void *mymemmove(void *dest, const void *src, size_t n)
{
    char temp[n];
    int i;
    char *d = dest;
    const char *s = src;

    for (i = 0; i < n; i++) 
        temp[i] = s[i];
    for (i = 0; i < n; i++) 
        d[i] = temp[i];

    return dest;
}


关于memcpy的实现:

void *mymemcpy(void *dest, const void *src, size_t n)
{
    char *d = dest;
    const char *s = src;
    int *di;
    const int *si;
    int r = n % 4;
    while (r--)
        *d++ = *s++;
    di = (int *)d;
    si = (const int*)s;
    n /= 4;
    while (n--)
        *di++ = *si++;
    return dest;
}


 

转载于:https://my.oschina.net/ashnah/blog/743672

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值