欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++?std::copy與memcpy區(qū)別小結(jié)

 更新時(shí)間:2024年05月08日 08:31:10   作者:魔法自動(dòng)機(jī)  
本文主要介紹了C++?std::copy與memcpy區(qū)別小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言:最近在讀項(xiàng)目源碼,發(fā)現(xiàn)有些地方用std::copy,有些地方用memcpy。但是并不知道為什么要這樣,但是原作者也不認(rèn)識(shí),就只好自己研究一下了。

對(duì)比

相同:

  • 都是復(fù)制拷貝函數(shù)。
  • 都是通過(guò)指針操作進(jìn)行內(nèi)存復(fù)制。

不同:

  • std::copy是C++中的函數(shù),memcpy是C中的函數(shù)。
  • std::copy更加靈活,可以在不同類型的對(duì)象之間進(jìn)行復(fù)制;memcpy只能用于字節(jié)級(jí)別的復(fù)制,不能處理自定義類型。
  • std::copy拷貝類的時(shí)候,會(huì)調(diào)用貝構(gòu)造函數(shù)或賦值運(yùn)算符來(lái)復(fù)制;memcpy只會(huì)按字節(jié)復(fù)制,不會(huì)調(diào)用類的任何成員函數(shù)。
  • std::copy的性能比memcpy會(huì)更好

使用場(chǎng)景

從兩者的不同點(diǎn)就可以看的出來(lái),大致使用場(chǎng)景的區(qū)別了。

適合std::copy:

  • 處理非平凡類型,使用memcpy會(huì)導(dǎo)致未定義行為,std::copy能確保處理正確的生命周期。
  • 對(duì)于結(jié)構(gòu)體或者類中有指針成員變量的情況,memcpy進(jìn)行拷貝只是進(jìn)行了淺拷貝,會(huì)導(dǎo)致指針成員變量的指向不正確,從而導(dǎo)致未定義行為。
  • 當(dāng)源和目標(biāo)內(nèi)存區(qū)域有重疊的時(shí)候。

適合memcpy:

  • 對(duì)于簡(jiǎn)單數(shù)據(jù)類型(例如int、char、float等基本的類型),使用memcpy而不是std::copy。
  • 當(dāng)源和目標(biāo)內(nèi)存區(qū)域沒有重疊,memcpy可以直接位拷貝,不會(huì)涉及迭代器和復(fù)制構(gòu)造函數(shù)等操作。

總結(jié)以下,C++才加入的類型或者自行定義的類型、涉及深拷貝、源和目標(biāo)內(nèi)存區(qū)域有重疊的時(shí)候適合std::copy,其它時(shí)候用memcpy好點(diǎn)。

補(bǔ)充:平凡類型trivial和非平凡類型non-trivial。
這個(gè)主要是針對(duì)類中的四個(gè)函數(shù)來(lái)說(shuō)的:構(gòu)造函數(shù)、復(fù)制構(gòu)造函數(shù)、賦值函數(shù)以及析構(gòu)函數(shù)。
如果滿足以下三點(diǎn)任意一點(diǎn),就是非平凡類型non-trivial:

  • 顯式定義了上面四種函數(shù)。
  • 類里面有非靜態(tài)非POD的成員(POD可以理解為包含平凡類、標(biāo)準(zhǔn)布局類)。
  • 有基類。

使用

std::copy

把src里面的內(nèi)容復(fù)制到dst。

vector<int>src= { 0, 1, 2, 3, 4 };
vector<int>dst(5, 0);
std::copy(src.begin(), src.end(),dst.begin());// src起始地址,src末尾下一個(gè),dst起始地址

memcpy

因?yàn)閙emcpy是C那邊的,所以用vector不太合適,適合簡(jiǎn)單的數(shù)據(jù)類型。

const char src[50] = "http://www.runoob.com";
char dst[50];
// strlen(src)不包括結(jié)束符
memcpy(dst, src, strlen(src)+1);// dst起始地址,src起始地址,復(fù)制長(zhǎng)度

到此這篇關(guān)于C++ std::copy與memcpy區(qū)別小結(jié)的文章就介紹到這了,更多相關(guān)C++ std::copy memcpy內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • opencv3/C++ FLANN特征匹配方式

    opencv3/C++ FLANN特征匹配方式

    今天小編就為大家分享一篇opencv3/C++ FLANN特征匹配方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-12-12
  • C語(yǔ)言如何計(jì)算兩個(gè)數(shù)的最小公倍數(shù)

    C語(yǔ)言如何計(jì)算兩個(gè)數(shù)的最小公倍數(shù)

    這篇文章主要介紹了C語(yǔ)言如何計(jì)算兩個(gè)數(shù)的最小公倍數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • C++容器適配器的概念與示例

    C++容器適配器的概念與示例

    C++?STL(標(biāo)準(zhǔn)模板庫(kù))是一套功能強(qiáng)大的?C++?模板類,提供了通用的模板類和函數(shù),這些模板類和函數(shù)可以實(shí)現(xiàn)多種流行和常用的算法和數(shù)據(jù)結(jié)構(gòu),如向量、鏈表、隊(duì)列、棧,今天我們來(lái)探究一下stl容器適配器的使用吧
    2023-01-01
  • VC++中HTControl控件類之CHTRichEdit富文本編輯控件實(shí)例

    VC++中HTControl控件類之CHTRichEdit富文本編輯控件實(shí)例

    這篇文章主要介紹了VC++中HTControl控件類之CHTRichEdit富文本編輯控件,是一個(gè)比較實(shí)用的功能,需要的朋友可以參考下
    2014-08-08
  • C語(yǔ)言 操作符#與##使用方法詳解

    C語(yǔ)言 操作符#與##使用方法詳解

    在類函數(shù)宏中(帶參數(shù)的宏),#號(hào)作為一個(gè)預(yù)處理運(yùn)算符,可以把記號(hào)轉(zhuǎn)換成字符串。##相當(dāng)于連接符,它會(huì)將兩邊的內(nèi)容連接起來(lái),形成新的標(biāo)識(shí)符,下面請(qǐng)看詳細(xì)的教程
    2022-04-04
  • C++深入講解類與對(duì)象之OOP面向?qū)ο缶幊膛c封裝

    C++深入講解類與對(duì)象之OOP面向?qū)ο缶幊膛c封裝

    學(xué)習(xí)過(guò)C語(yǔ)言的小伙伴知道:C語(yǔ)言是面向過(guò)程的,關(guān)注的是過(guò)程,分析出求解問(wèn)題的步驟,通過(guò)函數(shù)調(diào)用逐步解決問(wèn)題,接下來(lái)讓我們?cè)敿?xì)的了解
    2022-05-05
  • QT中QDockWidget控件的使用小結(jié)

    QT中QDockWidget控件的使用小結(jié)

    QDockWidget類提供了一個(gè)小部件,可以??吭赒MainWindow中,也可以作為桌面上的頂級(jí)窗口浮動(dòng),本文主要介紹了QT中QDockWidget控件的使用小結(jié),感興趣的可以了解一下
    2024-01-01
  • C/C++ 淺拷貝和深拷貝的實(shí)例詳解

    C/C++ 淺拷貝和深拷貝的實(shí)例詳解

    這篇文章主要介紹了C/C++ 淺拷貝和深拷貝的實(shí)例詳解的相關(guān)資料,幫助大家理解這部分知識(shí)提供了基礎(chǔ)知識(shí)及實(shí)例,需要的朋友可以參考下
    2017-08-08
  • C++?LeetCode1769移動(dòng)所有球到每個(gè)盒子最小操作數(shù)示例

    C++?LeetCode1769移動(dòng)所有球到每個(gè)盒子最小操作數(shù)示例

    這篇文章主要為大家介紹了C++?LeetCode1769移動(dòng)所有球到每個(gè)盒子所需最小操作數(shù)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • C++快速排序超詳細(xì)講解

    C++快速排序超詳細(xì)講解

    快速排序是一種高效的排序算法,通過(guò)分治法將數(shù)組劃分為兩部分,遞歸排序,直到整個(gè)數(shù)組有序,通過(guò)代碼解析和示例,詳細(xì)解釋了快速排序的工作原理和實(shí)現(xiàn)過(guò)程,需要的朋友可以參考下
    2025-03-03

最新評(píng)論