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高一些,如果還不明白的話可以看一些兩者的實現:

 

 


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;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章