91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

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

c++之對(duì)象構(gòu)造順序和銷(xiāo)毀

電子設(shè)計(jì) ? 來(lái)源:電子設(shè)計(jì) ? 作者:電子設(shè)計(jì) ? 2020-12-24 17:20 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、對(duì)象的構(gòu)造順序:

1、對(duì)于局部對(duì)象:

當(dāng)程序執(zhí)行流到達(dá)對(duì)象的定義語(yǔ)句時(shí)進(jìn)行構(gòu)造。下面還是用代碼來(lái)解析這句話(huà):

#include <stdio.h>
class Test

private:
int mi;
public:
Test(int i)

mi=i;
printf("Test(int i) is %d",mi);

Test(const Test& obj)

mi=obj.mi;
printf("Test(const Test&) obj is %d",mi);

};
int main()

int i = 0 ;
Test a1 =i;//Test(int i):0
while(i<3)

Test a2 = ++i;//Test(int i):1,2,3

if(i<4)

Test a = a1; //Test(const Test& obj is :0

else

Test a(100);

return 0;

輸出結(jié)果:

Test(int i) is 0
Test(int i) is 1
Test(int i) is 2
Test(int i) is 3
Test(const Test& obj) is 0

這里我們可以看出當(dāng)程序流執(zhí)行到相應(yīng)的構(gòu)造對(duì)象的那條執(zhí)行語(yǔ)句時(shí),就會(huì)調(diào)用構(gòu)造函數(shù)(或者拷貝構(gòu)造函數(shù))。goto語(yǔ)句想必大家不陌生,但是都害怕這玩意,下面我們加入goto語(yǔ)句看看會(huì)產(chǎn)生什么現(xiàn)象:

#include <stdio.h>
class Test{
private:
int mi;
public:
Test(int i)

mi=i;
printf("Test(int i) is %d",mi);

Test(const Test& obj)

mi=obj.mi;
printf("Test(const Test& obj is %d",mi);

};
int main()

int i = 0; //Test(int i) :0
Test a1 = i;
while( i <3)

Test a2 = ++i; //Test(int i) :1,2,3

goto end;
if(i <4)

Test a = a1;//Test(const Test&) obj is :0

else

Test a(100);

end:
return 0;

輸出結(jié)果:

Test(int i) is 0
Test(int i) is 1
Test(int i) is 2
Test(int i) is 3

從結(jié)果我們可以看出從if那條語(yǔ)句就被跳過(guò)了,沒(méi)有執(zhí)行到,這里這樣寫(xiě)的目的是為了引出,當(dāng)你使用goto語(yǔ)句,把對(duì)象給屏蔽了,后面你不能使用這個(gè)對(duì)象了,不然程序會(huì)出現(xiàn)大問(wèn)題:

#include <stdio.h>
class Test{
private:
int mi;
public:
Test(int i)

mi=i;
printf("Test(int i) is %d",mi);

Test(const Test& obj)

mi=obj.mi;
printf("Test(const Test& obj is %d",mi);

int getMi()

return mi;

};
int main()

int i = 0; //Test(int i) :0
Test a1 = i;
while( i <3)

Test a2 = ++i; //Test(int i) :1,2,3

goto end;
Test a(100);
end:
printf("a.mi is %d",a.getMi());
return 0;

輸出結(jié)果:

tt.cpp: In function ‘int main()’:
tt.cpp:32:1: error: jump to label ‘end’ [-fpermissive]
end:

tt.cpp:30:6: error: from here [-fpermissive]
goto end;

tt.cpp:31:12: error: crosses initialization of ‘Test a’
Test a(100);

這里就是上面所說(shuō)了的,對(duì)象被goto語(yǔ)句給屏蔽了,后面就不能使用這個(gè)對(duì)象來(lái)進(jìn)行操作了。

2、對(duì)于堆對(duì)象:

當(dāng)程序執(zhí)行流到達(dá)new語(yǔ)句時(shí)創(chuàng)建對(duì)象

使用new創(chuàng)建對(duì)象將自動(dòng)觸發(fā)構(gòu)造函數(shù)的調(diào)用

代碼演示:

#include <stdio.h>
class Test

private:
int mi;
public:
Test(int i)

mi = i;
printf("Test(int i): %d", mi);

Test(const Test& obj)

mi = obj.mi;
printf("Test(const Test& obj): %d", mi);

int getMi()

return mi;

};
int main()

int i = 0;
Test* a1 = new Test(i); // Test(int i): 0

while( ++i < 10 )
if( i % 2 )
new Test(i); // Test(int i): 1, 3, 5, 7, 9

if( i < 4 )
new Test(*a1);
else
new Test(100); // Test(int i): 100

return 0;

輸出結(jié)果:

Test(int i): 0
Test(int i): 1
Test(int i): 3
Test(int i): 5
Test(int i): 7
Test(int i): 9
Test(int i): 100

3、對(duì)于全局對(duì)象:

對(duì)象的構(gòu)造順序是不確定的

不同的編譯器使用不同的規(guī)則來(lái)確定構(gòu)造順序。

同樣還是來(lái)看代碼示例,這里我創(chuàng)建了幾個(gè)文件:tes1.cpp test2.cpp test3.cpp test4.cpp test.h;他們的內(nèi)容如下:

test1.cpp:

#include "test.h"
Test t4("t4");
int main()

Test t5("t5");

test2.cpp:

#include "test.h"
Test t1("t1");

test3.cpp:

#include "test.h"
Test t2("t2");

test4.cpp:

#include "test.h"
Test t3("t3");

test.h:

#ifndef _TEST_H_
#define _TEST_H_
#include <stdio.h>
class Test

public:
Test(const char* s)

printf("%s", s);

};
#endif

最后輸出結(jié)果:

root@txp-virtual-machine:/home/txp# g++ test1.cpp test2.cpp test3.cpp test4.cpp -o put
root@txp-virtual-machine:/home/txp# ./put
t4
t1
t2
t3
t5

4、小結(jié):

局部對(duì)象的構(gòu)造順序依賴(lài)程序的執(zhí)行流

堆對(duì)象的構(gòu)造順序依賴(lài)于new的使用順序

全局對(duì)象的構(gòu)造順序是不確定的

二、析構(gòu)函數(shù):

1、c++的類(lèi)中可以定義一個(gè)特殊的清理函數(shù),叫做析構(gòu)函數(shù),這個(gè)函數(shù)的功能與構(gòu)造函數(shù)相反,顧名思義就是銷(xiāo)毀的意思了。

2、定義:~ClassName()

析構(gòu)函數(shù)沒(méi)有參數(shù)也沒(méi)有返回值類(lèi)型聲明

析構(gòu)函數(shù)在對(duì)象銷(xiāo)毀時(shí)自動(dòng)被調(diào)用

代碼示例:

#include <stdio.h>
class Test

int mi;
public:
Test(int i)

mi = i;
printf("Test(): %d", mi);

~Test()

printf("~Test(): %d", mi);

};
int main()

Test t(1);

Test* pt = new Test(2);

delete pt;

return 0;

輸出結(jié)果:

Test(): 1
Test(): 2
~Test(): 2
~Test(): 1

3、析構(gòu)函數(shù)的定義準(zhǔn)則:

當(dāng)類(lèi)中自定義了構(gòu)造函數(shù),并且析構(gòu)函數(shù)中使用了系統(tǒng)資源(比如說(shuō),內(nèi)存的申請(qǐng),文件打開(kāi)),那么就需要自定義析構(gòu)函數(shù)了。

4、小結(jié):

析構(gòu)函數(shù)是對(duì)象銷(xiāo)毀時(shí)進(jìn)行處理的特殊函數(shù)

析構(gòu)函數(shù)在對(duì)象銷(xiāo)毀時(shí)自動(dòng)被調(diào)用

析構(gòu)函數(shù)是對(duì)象釋放系統(tǒng)資源的保障

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

    關(guān)注

    3

    文章

    4417

    瀏覽量

    67507
  • C++
    C++
    +關(guān)注

    關(guān)注

    22

    文章

    2124

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    從引腳到驗(yàn)證:硬件級(jí)SSD數(shù)據(jù)銷(xiāo)毀功能的六個(gè)可靠性審查要點(diǎn)

    當(dāng)數(shù)據(jù)安全要求達(dá)到“物理隔離失效”級(jí)別時(shí),SSD的內(nèi)置硬銷(xiāo)毀功能成為關(guān)鍵考量。本文提供一套評(píng)估框架,從觸發(fā)機(jī)制、銷(xiāo)毀徹底性、執(zhí)行可靠性及集成安全性四個(gè)維度,解析如何甄別真正可靠的物理硬銷(xiāo)毀方案,為高安全場(chǎng)景選型提供決策依據(jù)。
    的頭像 發(fā)表于 02-11 15:01 ?139次閱讀

    keil實(shí)現(xiàn)cc++混合編程

    起因項(xiàng)目中使用到一個(gè)開(kāi)源的模擬IIC的庫(kù),封裝的比較好,但是是使用c++寫(xiě)的。于是將其移植到自己的項(xiàng)目中,主要有以下三步操作: 在工程選項(xiàng)中 C/C++中去掉勾選 C99 Mode
    發(fā)表于 01-26 08:58

    C語(yǔ)言與C++的區(qū)別及聯(lián)系

    class等面向對(duì)象的特性和機(jī)制。但是,后來(lái)經(jīng)過(guò)一步步修訂和很多次演變,最終才形成了現(xiàn)如今這個(gè)支持一系列重大特性的龐大編程語(yǔ)言。 一、C語(yǔ)言是面向過(guò)程語(yǔ)言,而C++是面向對(duì)象語(yǔ)言
    發(fā)表于 12-24 07:23

    CC++之間的聯(lián)系

    ,后來(lái)才逐漸演變?yōu)橐环N成熟的面向對(duì)象編程語(yǔ)言。 總之,C語(yǔ)言和C++雖然有很多共同之處,但在編程范式、安全性、抽象層次等方面存在顯著差異。開(kāi)發(fā)者可以根據(jù)項(xiàng)目需求選擇合適的語(yǔ)言,C語(yǔ)言更
    發(fā)表于 12-11 06:51

    C語(yǔ)言和C++之間的區(qū)別是什么

    區(qū)別 1、面向對(duì)象編程 (OOP): C語(yǔ)言是一種面向過(guò)程的語(yǔ)言,它強(qiáng)調(diào)的是通過(guò)函數(shù)將任務(wù)分解為一系列步驟進(jìn)行執(zhí)行。 C++C語(yǔ)言的基礎(chǔ)上擴(kuò)展了面向
    發(fā)表于 12-11 06:23

    C/C++條件編譯

    條件編譯是一種在編譯時(shí)根據(jù)條件選擇性地包含或排除部分代碼的處理方法。在 C/C++ 中,條件編譯使用預(yù)處理指令 #ifdef、#endif、#else 和 #elif 來(lái)實(shí)現(xiàn)。常用的條件編譯指令有
    發(fā)表于 12-05 06:21

    C++程序異常的處理機(jī)制

    1、什么是異常處理? 有經(jīng)驗(yàn)的朋友應(yīng)該知道,在正常的CC++編程過(guò)程中難免會(huì)碰到程序不按照原本設(shè)計(jì)運(yùn)行的情況。 最常見(jiàn)的有除法分母為零,數(shù)組越界,內(nèi)存分配失效、打開(kāi)相應(yīng)文件失敗等等。 一個(gè)程序
    發(fā)表于 12-02 07:12

    C/C++代碼靜態(tài)測(cè)試工具Perforce QAC 2025.3的新特性

    ?Perforce Validate?中?QAC?項(xiàng)目的相對(duì)/根路徑的支持。C++?分析也得到了增強(qiáng),增加了用于檢測(cè) C++?并發(fā)問(wèn)題的新檢查,并改進(jìn)了實(shí)體名稱(chēng)和實(shí)
    的頭像 發(fā)表于 10-13 18:11 ?572次閱讀
    <b class='flag-5'>C</b>/<b class='flag-5'>C++</b>代碼靜態(tài)測(cè)試工具Perforce QAC 2025.3的新特性

    強(qiáng)實(shí)時(shí)運(yùn)動(dòng)控制內(nèi)核MotionRT750(六):us級(jí)高速交互C++,為智能裝備提速

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

    技能+1!如何在樹(shù)莓派上使用C++控制GPIO?

    在使用樹(shù)莓派時(shí),你會(huì)發(fā)現(xiàn)Python和Scratch是許多任務(wù)(包括GPIO編程)中最常用的編程語(yǔ)言。但你知道嗎,你也可以使用C++進(jìn)行GPIO編程,而且這樣做還有不少好處。借助WiringPi
    的頭像 發(fā)表于 08-06 15:33 ?4153次閱讀
    技能+1!如何在樹(shù)莓派上使用<b class='flag-5'>C++</b>控制GPIO?

    C++ 與 Python:樹(shù)莓派上哪種語(yǔ)言更優(yōu)?

    Python是樹(shù)莓派上的首選編程語(yǔ)言,我們的大部分教程都使用它。然而,C++在物聯(lián)網(wǎng)項(xiàng)目中同樣廣受歡迎且功能強(qiáng)大。那么,在樹(shù)莓派項(xiàng)目中選擇哪種語(yǔ)言更合適呢?Python因其簡(jiǎn)潔性、豐富的庫(kù)和資源而被
    的頭像 發(fā)表于 07-24 15:32 ?947次閱讀
    <b class='flag-5'>C++</b> 與 Python:樹(shù)莓派上哪種語(yǔ)言更優(yōu)?

    請(qǐng)問(wèn)如何在C++中使用NPU上的模型緩存?

    無(wú)法確定如何在 C++ 中的 NPU 上使用模型緩存
    發(fā)表于 06-24 07:25

    基于LockAI視覺(jué)識(shí)別模塊:C++目標(biāo)檢測(cè)

    本文檔基于瑞芯微RV1106的LockAI凌智視覺(jué)識(shí)別模塊,通過(guò)C++語(yǔ)言做的目標(biāo)檢測(cè)實(shí)驗(yàn)。本文檔展示了如何使用lockzhiner_vision_module::PaddleDet類(lèi)進(jìn)行目標(biāo)檢測(cè),并通過(guò)lockzhiner_vision_module::Visualize函數(shù)將檢測(cè)結(jié)果可視
    的頭像 發(fā)表于 06-06 13:56 ?841次閱讀
    基于LockAI視覺(jué)識(shí)別模塊:<b class='flag-5'>C++</b>目標(biāo)檢測(cè)

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

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

    C++學(xué)到什么程度可以找工作?

    C++學(xué)到什么程度可以找工作?要使用C++找到工作,特別是作為軟件開(kāi)發(fā)人員或相關(guān)職位,通常需要掌握以下幾個(gè)方面: 1. **語(yǔ)言基礎(chǔ)**:你需要對(duì)C++的核心概念有扎實(shí)的理解,包括但不限于指針、內(nèi)存
    發(fā)表于 03-13 10:19