日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

memmove和memcpy

發(fā)布時間:2024/4/11 编程问答 49 豆豆
生活随笔 收集整理的這篇文章主要介紹了 memmove和memcpy 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1.memmove

函數(shù)原型:void *memmove(void *dest, const void *source, size_t count)

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

參數(shù)說明:dest,source分別為目標(biāo)串和源串的首地址。count為要移動的字符的個數(shù)

函數(shù)說明:memmove用于從source拷貝count個字符到dest,如果目標(biāo)區(qū)域和源區(qū)域有重疊的話,memmove能夠保證源串在被覆蓋之前將重疊區(qū)域的字節(jié)拷貝到目標(biāo)區(qū)域中。

?

2.memcpy

?

函數(shù)原型:void *memcpy(void *dest,?const void *source,?size_t?count);

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

函數(shù)說明:memcpy功能和memmove相同,但是memcpy中dest和source中的區(qū)域不能重疊,否則會出現(xiàn)未知結(jié)果。

?

3.兩者區(qū)別

? 函數(shù)memcpy() ? 從source? 指向的區(qū)域向dest指向的區(qū)域復(fù)制count個字符,如果兩數(shù)組重疊,不定義該函數(shù)的行為。 ??
? 而memmove(),如果兩函數(shù)重疊,賦值仍正確進行。

? memcpy函數(shù)假設(shè)要復(fù)制的內(nèi)存區(qū)域不存在重疊,如果你能確保你進行復(fù)制操作的的內(nèi)存區(qū)域沒有任何重疊,可以直接用memcpy; ??
? 如果你不能保證是否有重疊,為了確保復(fù)制的正確性,你必須用memmove。

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

?

?


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))
?{
//?如果沒有重疊區(qū)域
???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?--)//不對是否存在重疊區(qū)域進行判斷
???*tmp_dest?++?=?*tmp_source?++;
?
return?dest;
}

總結(jié)

以上是生活随笔為你收集整理的memmove和memcpy的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。