void *memcpy(void *dst, const void *src, size_t count);
void *memmove(void *dst, const void *src, size_t count);
他們的作用是壹樣的,唯壹的區別是,當內存發生局部重疊的時候,memmove保證拷貝的結果是正確的,memcpy不保證拷貝的結果的正確。
二者的c語言實現很簡單,有興趣的朋友可以去看看。在實際情況下,這兩個函數都是用匯編實現的。
memmove在copy兩個有重疊區域的內存時可以保證copy的正確,而memcopy就不行了,但memcopy比memmove的速度要快壹些,如:
char s[] = "1234567890";
char* p1 = s;
char* p2 = s+2;
memcpy(p2, p1, 5)與memmove(p2, p1, 5)的結果就可能是不同的,memmove()可以將p1的頭5個字符"12345"正確拷貝至p2,而memcpy()的結果就不壹定正確了.
和memcpy相比,src和des有重疊的情況下,memmove可以保證數據的完整性.
memmove保證的原因很簡單,就是針對重疊的情況做特殊處理,因此速度會比memcpy慢壹些
具體的算法並不難想,畫個圖,分兩種情況
1. src的尾部和des的頭部重合
從src尾部開始,以地址 -- 的方式copy到des
2. src的頭部和des的尾部重合
從src頭部開始,以地址 ++ 的方式copy到des