zoukankan      html  css  js  c++  java
  • memcpy memmove区别和实现

    http://www.cnblogs.com/kekec/archive/2011/07/22/2114107.html

    memcpy与memmove的目的都是将N个字节的源内存地址的内容拷贝到目标内存地址中。

    但当源内存和目标内存存在重叠时,memcpy会出现错误,而memmove能正确地实施拷贝,但这也增加了一点点开销。

    memmove的处理措施:

    (1)当源内存的首地址等于目标内存的首地址时,不进行任何拷贝

    (2)当源内存的首地址大于目标内存的首地址时,实行正向拷贝

    (3)当源内存的首地址小于目标内存的首地址时,实行反向拷贝

    -- memcpy实现

    void* memcpy(void* dest, const void* src, size_t n)
    {
        char*      d = (char*) dest;
        const char*  s = (const char*) src;
        while(n-–)
           *d++ = *s++;
        return dest;
    }

    -- memmove实现

    void* memmove(void* dest, const void* src, size_t n)
    {
        char*     d  = (char*) dest;
        const char*  s = (const char*) src;
      
        if (s>d)
        {
             // start at beginning of s
             while (n--)
                *d++ = *s++;
        }
        else if (s<d)
        {
            // start at end of s
            d = d+n-1;
            s = s+n-1;
      
            while (n--)
               *d-- = *s--;
        }
        return dest;
    }

     

    示意图:

    1)内存低端 <-----s-----> <-----d-----> 内存高端 start at end of s
    (2)内存低端 <-----s--<==>--d----->      内存高端 start at end of s
    (3)内存低端 <-----sd----->              内存高端 do nothing
    (4)内存低端 <-----d--<==>--s----->      内存高端 start at beginning of s
    (5)内存低端 <-----d-----> <-----s-----> 内存高端 start at beginning of s
  • 相关阅读:
    POJ 2991(线段树)
    UVa_1592
    紫书 -- 大整数类
    在结构体中添加成员函数/C++
    双向队列
    用埃氏筛法生成质数表
    poj 3687(拓扑排序)
    它们其实都是“图”-- 最小生成树
    最小生成树(MST, Minimum Spanning Tree)
    他们其实都是“图”--最短路
  • 原文地址:https://www.cnblogs.com/sinferwu/p/9132775.html
Copyright © 2011-2022 走看看