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

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

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

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

電子設(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)解析這句話:

#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í)行到,這里這樣寫的目的是為了引出,當(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)造順序依賴程序的執(zhí)行流

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

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

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

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

2、定義:~ClassName()

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

析構(gòu)函數(shù)在對(duì)象銷毀時(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)類中自定義了構(gòu)造函數(shù),并且析構(gòu)函數(shù)中使用了系統(tǒng)資源(比如說(shuō),內(nèi)存的申請(qǐng),文件打開(kāi)),那么就需要自定義析構(gòu)函數(shù)了。

4、小結(jié):

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

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

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

審核編輯:符乾江
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(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

    文章

    4237

    瀏覽量

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

    關(guān)注

    21

    文章

    2085

    瀏覽量

    73302
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    OpenVINO2024 C++推理使用技巧

    很多人都使用OpenVINO新版的C++ 或者Python的SDK,都覺(jué)得非常好用,OpenVINO2022之后的版本C++ SDK做了大量的優(yōu)化與整理,已經(jīng)是非常貼近開(kāi)發(fā)的使用習(xí)慣與推理方式。與OpenCV的Mat對(duì)象對(duì)接方式
    的頭像 發(fā)表于 07-26 09:20 ?435次閱讀

    C++中實(shí)現(xiàn)類似instanceof的方法

    函數(shù),可實(shí)際上C++中沒(méi)有。但是別著急,其實(shí)C++中有兩種簡(jiǎn)單的方法可以實(shí)現(xiàn)類似Java中的instanceof的功能。 在 C++ 中,確定對(duì)象的類型是編程中實(shí)際需求,使開(kāi)發(fā)人員
    的頭像 發(fā)表于 07-18 10:16 ?355次閱讀
    <b class='flag-5'>C++</b>中實(shí)現(xiàn)類似instanceof的方法

    為什么很少用C++開(kāi)發(fā)單片機(jī)

    C語(yǔ)言是面向過(guò)程的語(yǔ)言,C++是面向對(duì)象的編程語(yǔ)言。結(jié)合本文來(lái)說(shuō),面向過(guò)程相比面向對(duì)象的編程,生成代碼量(bin文件)更小,運(yùn)行效率更高。
    發(fā)表于 03-25 14:26 ?654次閱讀
    為什么很少用<b class='flag-5'>C++</b>開(kāi)發(fā)單片機(jī)

    c語(yǔ)言,c++,java,python區(qū)別

    操作系統(tǒng)、嵌入式系統(tǒng)等對(duì)性能要求較高的場(chǎng)景。C語(yǔ)言的語(yǔ)法相對(duì)簡(jiǎn)單,學(xué)習(xí)曲線較平緩,也是學(xué)習(xí)其他高級(jí)語(yǔ)言的入門語(yǔ)言。 C++C++是在C語(yǔ)言的基礎(chǔ)上進(jìn)行擴(kuò)展和改進(jìn)的一種編程語(yǔ)言。它支
    的頭像 發(fā)表于 02-05 14:11 ?1366次閱讀

    vb語(yǔ)言和c++語(yǔ)言的區(qū)別

    Microsoft開(kāi)發(fā)的一種面向對(duì)象的事件驅(qū)動(dòng)編程語(yǔ)言。它的設(shè)計(jì)目標(biāo)是簡(jiǎn)化編程過(guò)程,讓初學(xué)者也能快速上手。與相比,C++語(yǔ)言是一種通用的、面向對(duì)象的編程語(yǔ)言,其設(shè)計(jì)目標(biāo)是提供高性能的
    的頭像 發(fā)表于 02-01 10:20 ?1522次閱讀

    C++簡(jiǎn)史:C++是如何開(kāi)始的

    MISRA C++:2023,MISRA? C++ 標(biāo)準(zhǔn)的下一個(gè)版本,來(lái)了!為了幫助您做好準(zhǔn)備,我們介紹了 Perforce 首席技術(shù)支持工程師 Frank van den Beuken 博士撰寫
    的頭像 發(fā)表于 01-11 09:00 ?427次閱讀
    <b class='flag-5'>C++</b>簡(jiǎn)史:<b class='flag-5'>C++</b>是如何開(kāi)始的

    基于C/C++面向對(duì)象的方式封裝socket通信類流程簡(jiǎn)析

    在掌握了基于 TCP 的套接字通信流程之后,為了方便使用,提高編碼效率,可以對(duì)通信操作進(jìn)行封裝,本著有淺入深的原則,先基于 C 語(yǔ)言進(jìn)行面向過(guò)程的函數(shù)封裝,然后再基于 C++ 進(jìn)行面向對(duì)象的類封裝。
    的頭像 發(fā)表于 12-26 10:00 ?1456次閱讀

    基于C/C++面向對(duì)象的方式封裝socket通信類

    在掌握了基于 TCP 的套接字通信流程之后,為了方便使用,提高編碼效率,可以對(duì)通信操作進(jìn)行封裝,本著有淺入深的原則,先基于 C 語(yǔ)言進(jìn)行面向過(guò)程的函數(shù)封裝,然后再基于 C++ 進(jìn)行面向對(duì)象的類封裝。
    的頭像 發(fā)表于 12-26 09:57 ?1140次閱讀

    C語(yǔ)言和C++中那些不同的地方

    C語(yǔ)言雖說(shuō)經(jīng)常和C++在一起被大家提起,但可千萬(wàn)不要以為它們是一個(gè)東西?,F(xiàn)在我們常用的C語(yǔ)言是C89標(biāo)準(zhǔn),C++
    的頭像 發(fā)表于 12-07 14:29 ?773次閱讀
    <b class='flag-5'>C</b>語(yǔ)言和<b class='flag-5'>C++</b>中那些不同的地方

    c語(yǔ)言中順序結(jié)構(gòu)的基本流程

    C語(yǔ)言是一種通用的編程語(yǔ)言,注重結(jié)構(gòu)化編程和順序結(jié)構(gòu)。順序結(jié)構(gòu)是C語(yǔ)言編程中最簡(jiǎn)單也是最基本的控制結(jié)構(gòu)之一,它按照代碼的編寫順序一行一行地執(zhí)
    的頭像 發(fā)表于 11-22 10:20 ?781次閱讀

    探索C++的編程習(xí)慣與編程要點(diǎn)

    C++的類可以分為帶指針數(shù)據(jù)成員與不帶指針數(shù)據(jù)成員兩類,complex就屬于不帶指針成員的類。而這里要說(shuō)的字符串類String,一般的實(shí)現(xiàn)會(huì)帶有一個(gè)char *指針。帶指針數(shù)據(jù)成員的類,需要自己實(shí)現(xiàn)class三大件:拷貝構(gòu)造函數(shù)、拷貝賦值函數(shù)、析構(gòu)函數(shù)。
    的頭像 發(fā)表于 11-14 09:25 ?329次閱讀
    探索<b class='flag-5'>C++</b>的編程習(xí)慣與編程要點(diǎn)

    C++之父新作帶你勾勒現(xiàn)代C++地圖

    為了幫助大家解決這些痛點(diǎn)問(wèn)題,讓大家領(lǐng)略現(xiàn)代C++美,掌握其中的精髓,更好地使用C++,C++之父Bjarne Stroustrup坐不住了,他親自操刀寫就了這本《
    的頭像 發(fā)表于 10-30 16:35 ?696次閱讀
    <b class='flag-5'>C++</b>之父新作帶你勾勒現(xiàn)代<b class='flag-5'>C++</b>地圖

    靜態(tài)代碼塊、構(gòu)造代碼塊、構(gòu)造函數(shù)及普通代碼塊的執(zhí)行順序

    在Java中,靜態(tài)代碼塊、構(gòu)造代碼塊、構(gòu)造函數(shù)、普通代碼塊的執(zhí)行順序是一個(gè)筆試的考點(diǎn),通過(guò)這篇文章希望大家能徹底了解它們之間的執(zhí)行順序。 1、靜態(tài)代碼塊 ①、格式 在java類中(方法
    的頭像 發(fā)表于 10-09 15:40 ?981次閱讀
    靜態(tài)代碼塊、<b class='flag-5'>構(gòu)造</b>代碼塊、<b class='flag-5'>構(gòu)造</b>函數(shù)及普通代碼塊的執(zhí)行<b class='flag-5'>順序</b>

    C++程序設(shè)計(jì)精簡(jiǎn)版

    章 指針第 7 章 自定義數(shù)據(jù)類型 第 3 篇 基于對(duì)象的程序設(shè)計(jì)第 8 章 類和對(duì)象第 9 章 關(guān)于類和對(duì)象的進(jìn)一步討論第 10 章 運(yùn)算符重載 第 4 篇 面向對(duì)象的程序設(shè)計(jì)第
    發(fā)表于 10-09 07:26

    常用ARM指令集和匯編

    delete 會(huì)調(diào)用對(duì)象的析構(gòu)函數(shù),和 new 對(duì)應(yīng) free 只會(huì)釋放內(nèi)存,new 調(diào)用構(gòu)造函數(shù)。malloc與 free 是 C++/C 語(yǔ)言的標(biāo)準(zhǔn)庫(kù)函數(shù),new/delete 是
    發(fā)表于 09-25 06:53