1. 程式人生 > >memmove和memcpy

memmove和memcpy

1.memmove

函式原型:void *memmove(void *dest, const void *source, size_t count)

返回值說明:返回指向dest的void *指標

引數說明:dest,source分別為目標串和源串的首地址。count為要移動的字元的個數

函式說明:memmove用於從source拷貝count個字元到dest,如果目標區域和源區域有重疊的話,memmove能夠保證源串在被覆蓋之前將重疊區域的位元組拷貝到目標區域中。

2.memcpy

函式原型:void *memcpy(void *dest, const void *source, size_t count);

返回值說明:返回指向dest的void *指標

函式說明:memcpy功能和memmove相同,但是memcpy中dest和source中的區域不能重疊,否則會出現未知結果。

3.兩者區別

    函式memcpy() 從source 指向的區域向dest指向的區域複製count個字元,如果兩陣列重疊,不定義該函式的行為。
    而memmove(),如果兩函式重疊,賦值仍正確進行。

    memcpy函式假設要複製的記憶體區域不存在重疊,如果你能確保你進行復制操作的的記憶體區域沒有任何重疊,可以直接用memcpy;
    如果你不能保證是否有重疊,為了確保複製的正確性,你必須用memmove。

    memcpy的效率會比memmove高一些,如果還不明白的話可以看一些兩者的實現:

  1. void *memmove(void *dest, constvoid *source, size_t count)
  2. {
  3. assert((NULL != dest) && (NULL != source));
  4. char *tmp_source, *tmp_dest;
  5. tmp_source = (char *)source;
  6. tmp_dest = (char *)dest;
  7. if((dest + count<source) || (source + count) <dest))
  8. {// 如果沒有重疊區域
  9. while(count--)
  10.       *tmp_dest++ = *tmp_source++;
  11. }
  12. else
  13. { //如果有重疊
  14. tmp_source += count - 1;
  15. tmp_dest += count - 1;
  16. while(count--)
  17.     *--tmp_dest = *--tmp;
  18. }
  19. return dest;
  20. }
  21. void *memcpy(void *dest, constvoid *source, size_t count)
  22. {
  23. assert((NULL != dest) && (NULL != source));
  24. char *tmp_dest = (char *)dest;
  25. char *tmp_source = (char *)source;
  26. while(count --)//不對是否存在重疊區域進行判斷
  27.     *tmp_dest ++ = *tmp_source ++;
  28. return dest;
  29. }