memcpy与memmove函数

本文介绍了C语言中的memcpy和memmove函数,强调了它们在处理内存区域重叠时的不同行为。memcpy可能在源和目标重叠时导致不确定的结果,而memmove能够正确处理这种场景。此外,文章还提及了在某些笔试中如何实现memmove函数的基本思路,并简单提及了二分查找和快速排序等经典算法。
摘要由CSDN通过智能技术生成

memcpy()与memmove()是C语言中的函数,其声明在头文件string.h中,具体声明如下:

void* __cdecl memcpy(
    _Out_writes_bytes_all_(_Size) void* 	  _Dst,
    _In_reads_bytes_(_Size)       void const* _Src,
    _In_                          size_t      _Size
    );
    
_VCRTIMP void* __cdecl memmove(
    _Out_writes_bytes_all_opt_(_Size) void*       _Dst,
    _In_reads_bytes_opt_(_Size)       void const* _Src,
    _In_                              size_t      _Size
    );

说明
memcpy将计数字节从src复制到目标;wmemcpy复制计数宽字符(两个字节)。 如果源和目标重叠,则memcpy的行为是不确定的。 使用memmove处理重叠区域。

参考
https://docs.microsoft.com/zh-cn/cpp/c-runtime-library/reference/memcpy-wmemcpy?view=vs-2019

在C/C++一些笔试中较常见要求不用标准库函数,实现mommove函数的功能,这里进行一下自我总结:
函数原型

void *memcpy(void *dst, const void *src, size_t size);
void *memmove(void *dst, const void *src, size_t size);

函数实现

void* memcpy(void* dst, const void* src, size_t size)
{
   
    char *dst_t = (char*)dst;
    char *src_t = (char*)src;
 
    while(size--) {
   
        *dst_t++ = *src_t++;
    }
    return dst;
}

由于memcpy是不去处理覆盖的情况的,所以已经不推荐使用了,而memmove对于src<dst<src+size的情况需要从后往前移动,才能正确处理覆盖的情况。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值