chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

C++之拷貝構造函數(shù)的淺copy及深copy

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2020-12-24 15:31 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、深拷貝和淺拷貝構造函數(shù)總結:

1、兩個特殊的構造函數(shù):

(1)無參構造函數(shù):

沒有參數(shù)的構造函數(shù)

Class Test

public:
Test()

//這是一個無參構造函數(shù)

};

當類中沒有定義構造函數(shù)時,編譯器默認提供一個無參構造函數(shù),并且其函數(shù)體為空;換句話來說,就是我們在類中,不用我們程序猿自己寫,編譯就自動提供了無參構造函數(shù)(只是我們?nèi)庋劭床坏剑。?/p>

#include <iostream>
#include <string>
class Test{
//編譯器默認給我們提供了一個無參構造函數(shù),只是我們?nèi)庋劭床坏?br /> };
int main()

Test t;
return 0;

結果輸出(編譯時能夠通過的):

root@txp-virtual-machine:/home/txp# g++ test.cpp
root@txp-virtual-machine:/home/txp#

(2)拷貝構造函數(shù):

參數(shù)為const class_name&的構造函數(shù)

class Test{
public:
Test(const Test& p)




當類中沒有定義拷貝構造函數(shù)時,編譯器默認提供了一個拷貝構造函數(shù),簡單的進行成員變量的值賦值

#include <iostream>
#include <string>
class Test{
private:
int i;
int j;
public:
Test(const Test& p)編譯器默認提供這樣操作的

i = p.i;
j = p.j;

};
int main()

Test t;
return 0;

輸出結果(編譯可以通過):

root@txp-virtual-machine:/home/txp# g++ test.cpp
root@txp-virtual-machine:/home/txp#

(3)注意:

在寫程序的時候,定義的類對象初始化時看屬于哪種類型的:

Test t;//對應無參構造函數(shù)
Test t(1);//對應有參構造函數(shù)
Test t1;
Test t2=t1;//對應拷貝構造函數(shù)

比如下面我定義的類對象屬于無參構造函數(shù)(當然前提是你手寫了其他構造函數(shù),雖然說編譯器會默認提供,但是既然要手寫,那么三種構造函數(shù)就在定義類對象的時候按需求來寫),如果只寫了有參數(shù)構造函數(shù),那么編譯器就會報錯:

#include <iostream>
#include <string>
class Test{
private:
int i;
int j;
public:
Test(int a)

i = 9;
j=8;

Test(const Test& p)

i = p.i;
j = p.j;

};
int main()

Test t;
return 0;

輸出結果:

root@txp-virtual-machine:/home/txp# g++ test.cpp
test.cpp: In function ‘int main()’:
test.cpp:25:9: error: no matching function for call to ‘Test::Test()’
Test t;

test.cpp:25:9: note: candidates are:
test.cpp:15:3: note: Test::Test(const Test&)
Test(const Test& p)

test.cpp:15:3: note: candidate expects 1 argument, 0 provided
test.cpp:10:3: note: Test::Test(int)
Test(int a)

test.cpp:10:3: note: candidate expects 1 argument, 0 provided

4、拷貝構造函數(shù)的意義:

(1)淺拷貝

拷貝后對象的物理狀態(tài)相同

(2)深拷貝

拷貝后對象的邏輯狀態(tài)相同

(3)編譯器提供的拷貝構造函數(shù)只進行淺拷貝

代碼版本一:

#include <stdio.h>
#include <string>
class Test{
private:
int i;
int j;
int *p;
public:
int getI()

return i;

int getJ()

return j;

int *getP()

return p;

Test(int a)

i = 2;
j = 3;
p = new int;
*p = a;

void free()

delete p;

};
int main()

Test t1(3);//Test t1 3;
Test t2 = t1;
printf("t1.i = %d, t1.j = %d, t1.p = %p", t1.getI(), t1.getJ(), t1.getP());
printf("t2.i = %d, t2.j = %d, t2.p = %p", t2.getI(), t2.getJ(), t2.getP());
t1.free();
t2.free();

return 0;

輸出結果:

root@txp-virtual-machine:/home/txp# g++ test.cpp
root@txp-virtual-machine:/home/txp# ./a.out
t1.i = 2, t1.j = 3, t1.p = 0x1528010
t2.i = 2, t2.j = 3, t2.p = 0x1528010
*** Error in `./a.out': double free or corruption (fasttop): 0x0000000001528010 ***
Aborted (core dumped)

注解:出現(xiàn)了段錯誤,仔細分析,我們發(fā)現(xiàn)這里釋放了堆空間兩次(因為我們這里沒有調(diào)用拷貝構造函數(shù),也就是自己去寫拷貝構造函數(shù);所以這種情況是淺拷貝,不能釋放兩次堆空間):

代碼版本二(加上拷貝構造函數(shù)):

#include <stdio.h>
#include <string>
class Test{
private:
int i;
int j;
int *p;
public:
int getI()

return i;

int getJ()

return j;

int *getP()

return p;

Test(int a)

i = 2;
j = 3;
p = new int;
*p = a;

Test(const Test& t)

i = t.i;
j = t.j;
p = new int;
*p = *t.p;

void free()

delete p;

};
int main()

Test t1(4);
Test t2 = t1;
printf("t1.i = %d, t1.j = %d, t1.p = %p", t1.getI(), t1.getJ(), t1.getP());
printf("t2.i = %d, t2.j = %d, t2.p = %p", t2.getI(), t2.getJ(), t2.getP());
t1.free();
t2.free();
return 0;

輸出結果:

root@txp-virtual-machine:/home/txp# g++ test.cpp
root@txp-virtual-machine:/home/txp# ./a.out
t1.i = 2, t1.j = 3, t1.p = 0xb0a010
t2.i = 2, t2.j = 3, t2.p = 0xb0a030

注解:從打印的p地址空間來看,就知釋放的兩個對象的堆空間不同,不再是指向同一堆空間了;同時我們發(fā)現(xiàn)淺拷貝只是簡單數(shù)值上的進行賦值而已;深拷貝不只是簡單的值賦值,而是從內(nèi)存的角度來看,是操作不同的內(nèi)存。

5、什么時候需要進行深拷貝?

(1)對象中有成員指代了系統(tǒng)中的資源

成員指向了動態(tài)內(nèi)存空間

成員打開了外存中的文件

成員使用了系統(tǒng)中的網(wǎng)絡端口

注意:一般來說,自定義拷貝構造函數(shù)(也就是我們自己手寫的),必然需要實現(xiàn)深拷貝!

二、總結:

C++編譯器會默認提供構造函數(shù)

無參構造函數(shù)用于定義對象的默認初始化狀態(tài)

拷貝構造函數(shù)在創(chuàng)建對象時拷貝對象的狀態(tài)

對象的拷貝有淺拷貝和深拷貝兩種方式。

好了,今天的分享就到這里,如果文章中有錯誤或者不理解的地方,可以交流互動,一起進步。我是txp,下期見!

審核編輯:符乾江
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 可編程邏輯
    +關注

    關注

    7

    文章

    526

    瀏覽量

    45298
  • C++
    C++
    +關注

    關注

    22

    文章

    2121

    瀏覽量

    76687
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    C++程序異常的處理機制

    運行代碼進行分離,使得程序更加模塊化;另一方面,C++的異常處理可以不需要異常處理在異常發(fā)生時的同一個函數(shù),而是可以在更上層合適的位置進行處理。 下面,我們一起來看看C++的異常處理。 2、異常處理
    發(fā)表于 12-02 07:12

    強實時運動控制內(nèi)核MotionRT750(六):us級高速交互C++,為智能裝備提速

    Windows下運動控制實時內(nèi)核MotionRT750的高速交互C++
    的頭像 發(fā)表于 09-04 14:50 ?463次閱讀
    強實時運動控制內(nèi)核MotionRT750(六):us級高速交互<b class='flag-5'>之</b><b class='flag-5'>C++</b>,為智能裝備提速

    基于LockAI視覺識別模塊:C++目標檢測

    本文檔基于瑞芯微RV1106的LockAI凌智視覺識別模塊,通過C++語言做的目標檢測實驗。本文檔展示了如何使用lockzhiner_vision_module::PaddleDet類進行目標檢測,并通過lockzhiner_vision_module::Visualize函數(shù)
    的頭像 發(fā)表于 06-06 13:56 ?597次閱讀
    基于LockAI視覺識別模塊:<b class='flag-5'>C++</b>目標檢測

    飛凌嵌入式ElfBoard ELF 1板卡-uboot編譯system.map/uboot.map

    system.map是一個符號表,其中包括符號名、符號類型、符號值。符號(sysmbol):包括已定義的符號(對應全局變量和static變量和定義的函數(shù)的名字)和未定義符號(未定義的函數(shù)的名字和引用
    發(fā)表于 05-22 11:22

    主流的 MCU 開發(fā)語言為什么是 C 而不是 C++?

    在單片機的地界兒里,C語言穩(wěn)坐中軍帳,C++想分杯羹?難嘍。咱電子工程師天天跟那針尖大的內(nèi)存空間較勁,C++那些花里胡哨的玩意兒,在這兒真玩不轉。先說內(nèi)存這道坎兒。您當stm32f4的256kRAM
    的頭像 發(fā)表于 05-21 10:33 ?768次閱讀
    主流的 MCU 開發(fā)語言為什么是 <b class='flag-5'>C</b> 而不是 <b class='flag-5'>C++</b>?

    嵌入式學習-飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間與用戶空間的數(shù)據(jù)拷貝獲取用戶空間數(shù)據(jù)

    例程代碼路徑:ELF 1開發(fā)板資料包\\03-例程源碼\\03-2 驅動例程源碼\\03_內(nèi)核空間與用戶空間的數(shù)據(jù)拷貝\\copy_form_user 在copy_to_user.c源碼的基礎上添加
    發(fā)表于 03-22 09:25

    嵌入式學習-飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間與用戶空間的數(shù)據(jù)拷貝獲取內(nèi)核空間數(shù)據(jù)

    例程代碼路徑:ELF 1開發(fā)板資料包\\03-例程源碼\\03-2 驅動例程源碼\\03_內(nèi)核空間與用戶空間的數(shù)據(jù)拷貝\\copy_to_user 在mydevice-auto.c源碼的基礎上
    發(fā)表于 03-21 14:00

    飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間與用戶空間的數(shù)據(jù)拷貝獲取用戶空間數(shù)據(jù)

    例程代碼路徑:ELF 1開發(fā)板資料包\\03-例程源碼\\03-2 驅動例程源碼\\03_內(nèi)核空間與用戶空間的數(shù)據(jù)拷貝\\copy_form_user 在copy_to_user.c源碼的基礎上添加
    發(fā)表于 03-21 13:58

    嵌入式學習-飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間與用戶空間的數(shù)據(jù)拷貝數(shù)據(jù)拷貝介紹

    空間之間進行數(shù)據(jù)傳輸時,需要進行數(shù)據(jù)拷貝操作。Linux內(nèi)核提供了幾種方法來實現(xiàn)內(nèi)核空間與用戶空間之間的數(shù)據(jù)拷貝copy_to_user()和copy_from_user()這兩個
    發(fā)表于 03-20 11:50

    飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間與用戶空間的數(shù)據(jù)拷貝獲取內(nèi)核空間數(shù)據(jù)

    拷貝\\copy_to_user在mydevice-auto.c源碼的基礎上進行添加,重命名為copy_to_user.c(一)添加頭文件#include(二)定義變量#define
    發(fā)表于 03-20 11:48

    飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間與用戶空間的數(shù)據(jù)拷貝數(shù)據(jù)拷貝介紹

    空間與用戶空間之間的數(shù)據(jù)拷貝。copy_to_user()和copy_from_user()這兩個函數(shù)用于在內(nèi)核空間和用戶空間之間進行數(shù)據(jù)拷貝
    發(fā)表于 03-19 08:55

    基于OpenHarmony標準系統(tǒng)的C++公共基礎類庫案例:ThreadPoll

    1、程序簡介該程序是基于OpenHarmony標準系統(tǒng)的C++公共基礎類庫的線程池處理:ThreadPoll。本案例完成如下工作:創(chuàng)建1個線程池,設置該線程池內(nèi)部有1024個線程空間。啟動5個線程
    的頭像 發(fā)表于 02-10 18:09 ?592次閱讀
    基于OpenHarmony標準系統(tǒng)的<b class='flag-5'>C++</b>公共基礎類庫案例:ThreadPoll

    Spire.XLS for C++組件說明

    Spire.XLS for C++ 是一款專業(yè)的 C++ Excel 組件,可以用在各種 C++ 框架和應用程序中。Spire.XLS for C++ 提供了一個對象模型 Excel
    的頭像 發(fā)表于 01-14 09:40 ?1289次閱讀
    Spire.XLS for <b class='flag-5'>C++</b>組件說明

    EE-112:模擬C++中的類實現(xiàn)

    電子發(fā)燒友網(wǎng)站提供《EE-112:模擬C++中的類實現(xiàn).pdf》資料免費下載
    發(fā)表于 01-03 15:15 ?0次下載
    EE-112:模擬<b class='flag-5'>C++</b>中的類實現(xiàn)

    運動控制卡周期上報實時數(shù)據(jù)IO狀態(tài)C++

    使用C++進行運動控制卡的周期上報功能實現(xiàn)
    的頭像 發(fā)表于 12-17 13:59 ?1513次閱讀
    運動控制卡周期上報實時數(shù)據(jù)IO狀態(tài)<b class='flag-5'>之</b><b class='flag-5'>C++</b>篇