c - memcpy() 与 memmove()

标签 c memcpy memmove

我试图理解 memcpy() 之间的区别和 memmove() ,并且我已经阅读了 memcpy() 不处理重叠源和目标而 memmove() 处理的文本。

但是,当我在重叠的内存块上执行这两个函数时,它们都给出了相同的结果。例如,以 memmove() 帮助页面上的以下 MSDN 示例为例:-

有没有更好的例子来理解memcpy的缺点以及memmove是如何解决的?

// crt_memcpy.c
// Illustrate overlapping copy: memmove always handles it correctly; memcpy may handle
// it correctly.

#include <memory.h>
#include <string.h>
#include <stdio.h>

char str1[7] = "aabbcc";

int main( void )
{
    printf( "The string: %s\n", str1 );
    memcpy( str1 + 2, str1, 4 );
    printf( "New string: %s\n", str1 );

    strcpy_s( str1, sizeof(str1), "aabbcc" );   // reset string

    printf( "The string: %s\n", str1 );
    memmove( str1 + 2, str1, 4 );
    printf( "New string: %s\n", str1 );
}

输出:

The string: aabbcc
New string: aaaabb
The string: aabbcc
New string: aaaabb

最佳答案

对于您的示例没有表现出任何奇怪的行为,我并不感到惊讶。尝试将 str1 复制到 str1+2,然后看看会发生什么。 (实际上可能没有什么不同,取决于编译器/库。)

一般来说,memcpy 的实现方式简单(但速度快)。简单地说,它只是循环遍历数据(按顺序),从一个位置复制到另一个位置。这可能导致源在读取时被覆盖。

Memmove 做了更多工作以确保其正确处理重叠。

编辑:

(不幸的是,我找不到像样的例子,但这些都可以)。对比 memcpymemmove此处显示的实现。 memcpy 只是循环,而 memmove 执行测试以确定循环的方向以避免损坏数据。这些实现相当简单。大多数高性能实现都比较复杂(涉及一次复制字大小的 block 而不是字节)。

关于c - memcpy() 与 memmove(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4415910/

相关文章:

c - 从 sqlite db 获取 blob,无需 memcpy

c++ - 使用 malloc : why did it happen? 的内存分配导致堆损坏

rust - 将结构复制到 Rust 中的特定内存位置

arrays - 如何确定 C 中数组的大小?

c++ - memcpy 在尝试 ‘fast’ pimpl 期间未优化

c++ - 变量的字节表示形式出现意外结果

c++ - 在内存中设置的二维数组是否与模拟二维数组的一维数组连续相似?

c++ - 在 C++ 的构造函数中使用 memmove 初始化整个对象

c++ - 使用 void 指针作为 FFI 接口(interface)类型的好处

c - 为什么我可以读取 3 个结构,但只分配 2 个?