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高一些,如果還不明白的話可以看一些兩者的實現:
?
?
void?*memmove(void?*dest,?const?void?*source,?size_t?count)
{
?assert((NULL?!=?dest)?&&?(NULL?!=?source));
?char?*tmp_source,?*tmp_dest;
?tmp_source?=?(char?*)source;
?tmp_dest?=?(char?*)dest;
?if((dest?+?count<source)?||?(source?+?count)?<dest))
?{//?如果沒有重疊區域
???while(count--)
?????*tmp_dest++?=?*tmp_source++;
}
else
{?//如果有重疊
?tmp_source?+=?count?-?1;
?tmp_dest?+=?count?-?1;
?while(count--)
???*--tmp_dest?=?*--tmp;
}
return?dest;
}
?
?
?
void?*memcpy(void?*dest,?const?void?*source,?size_t?count)
{
?assert((NULL?!=?dest)?&&?(NULL?!=?source));
?char?*tmp_dest?=?(char?*)dest;
?char?*tmp_source?=?(char?*)source;
?while(count?--)//不對是否存在重疊區域進行判斷
???*tmp_dest?++?=?*tmp_source?++;
?return?dest;
}
總結
以上是生活随笔為你收集整理的memmove和memcpy的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: STL中map用法详解
- 下一篇: DLL入门浅析(1)——如何建立DLL