衡阳派盒市场营销有限公司

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

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

3天內不再提示

c++之對象構造順序和銷毀

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2020-12-24 17:20 ? 次閱讀

一、對象的構造順序:

1、對于局部對象:

當程序執行流到達對象的定義語句時進行構造。下面還是用代碼來解析這句話:

#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;

輸出結果:

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

這里我們可以看出當程序流執行到相應的構造對象的那條執行語句時,就會調用構造函數(或者拷貝構造函數)。goto語句想必大家不陌生,但是都害怕這玩意,下面我們加入goto語句看看會產生什么現象:

#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;

輸出結果:

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

從結果我們可以看出從if那條語句就被跳過了,沒有執行到,這里這樣寫的目的是為了引出,當你使用goto語句,把對象給屏蔽了,后面你不能使用這個對象了,不然程序會出現大問題:

#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;

輸出結果:

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);

這里就是上面所說了的,對象被goto語句給屏蔽了,后面就不能使用這個對象來進行操作了。

2、對于堆對象:

當程序執行流到達new語句時創建對象

使用new創建對象將自動觸發構造函數的調用

代碼演示:

#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;

輸出結果:

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、對于全局對象:

對象的構造順序是不確定的

不同的編譯器使用不同的規則來確定構造順序。

同樣還是來看代碼示例,這里我創建了幾個文件:tes1.cpp test2.cpp test3.cpp test4.cpp test.h;他們的內容如下:

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

最后輸出結果:

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、小結:

局部對象的構造順序依賴程序的執行流

堆對象的構造順序依賴于new的使用順序

全局對象的構造順序是不確定的

二、析構函數:

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

2、定義:~ClassName()

析構函數沒有參數也沒有返回值類型聲明

析構函數在對象銷毀時自動被調用

代碼示例:

#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;

輸出結果:

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

3、析構函數的定義準則:

當類中自定義了構造函數,并且析構函數中使用了系統資源(比如說,內存的申請,文件打開),那么就需要自定義析構函數了。

4、小結:

析構函數是對象銷毀時進行處理的特殊函數

析構函數在對象銷毀時自動被調用

析構函數是對象釋放系統資源的保障

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

    關注

    3

    文章

    4346

    瀏覽量

    62972
  • C++
    C++
    +關注

    關注

    22

    文章

    2114

    瀏覽量

    73857
收藏 人收藏

    評論

    相關推薦

    Spire.XLS for C++組件說明

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

    運動控制卡周期上報實時數據IO狀態C++

    使用C++進行運動控制卡的周期上報功能實現
    的頭像 發表于 12-17 13:59 ?342次閱讀
    運動控制卡周期上報實時數據IO狀態<b class='flag-5'>之</b><b class='flag-5'>C++</b>篇

    同樣是函數,在CC++中有什么區別

    同樣是函數,在 CC++ 中有什么區別? 第一個返回值。 C語言的函數可以不寫返回值類型,編譯器會默認為返回 int。 但是 C++ 的函數,除了
    的頭像 發表于 11-29 10:25 ?429次閱讀

    C7000 C/C++優化指南用戶手冊

    電子發燒友網站提供《C7000 C/C++優化指南用戶手冊.pdf》資料免費下載
    發表于 11-09 15:00 ?0次下載
    <b class='flag-5'>C</b>7000 <b class='flag-5'>C</b>/<b class='flag-5'>C++</b>優化指南用戶手冊

    SpringBean初始化順序

    Spring bean是Spring框架在運行時管理的對象。Spring bean是任何Spring應用程序的基本構建塊。我們編寫的大多數應用程序邏輯代碼都將放在Spring bean中。 執行順序
    的頭像 發表于 11-06 16:04 ?216次閱讀
    SpringBean初始化<b class='flag-5'>順序</b>

    TMS320C6000優化C/C++編譯器v8.3.x

    電子發燒友網站提供《TMS320C6000優化C/C++編譯器v8.3.x.pdf》資料免費下載
    發表于 11-01 09:35 ?0次下載
    TMS320<b class='flag-5'>C</b>6000優化<b class='flag-5'>C</b>/<b class='flag-5'>C++</b>編譯器v8.3.x

    C語言和C++中結構體的區別

    同樣是結構體,看看在C語言和C++中有什么區別?
    的頭像 發表于 10-30 15:11 ?356次閱讀

    C7000優化C/C++編譯器

    電子發燒友網站提供《C7000優化C/C++編譯器.pdf》資料免費下載
    發表于 10-30 09:45 ?0次下載
    <b class='flag-5'>C</b>7000優化<b class='flag-5'>C</b>/<b class='flag-5'>C++</b>編譯器

    ostream在c++中的用法

    ostream 是 C++ 標準庫中一個非常重要的類,它位于 頭文件中(實際上,更常見的是通過包含 頭文件來間接包含 ,因為 包含了 和 )。 ostream 類及其派生類(如 std::cout
    的頭像 發表于 09-20 15:11 ?941次閱讀

    OpenVINO2024 C++推理使用技巧

    很多人都使用OpenVINO新版的C++ 或者Python的SDK,都覺得非常好用,OpenVINO2022之后的版本C++ SDK做了大量的優化與整理,已經是非常貼近開發的使用習慣與推理方式。與OpenCV的Mat對象對接方式
    的頭像 發表于 07-26 09:20 ?1057次閱讀

    C++語言基礎知識

    電子發燒友網站提供《C++語言基礎知識.pdf》資料免費下載
    發表于 07-19 10:58 ?7次下載

    C++中實現類似instanceof的方法

    函數,可實際上C++中沒有。但是別著急,其實C++中有兩種簡單的方法可以實現類似Java中的instanceof的功能。 在 C++ 中,確定對象的類型是編程中實際需求,使開發人員
    的頭像 發表于 07-18 10:16 ?673次閱讀
    <b class='flag-5'>C++</b>中實現類似instanceof的方法

    鴻蒙OS開發實例:【Native C++

    使用DevEco Studio創建一個Native C++應用。應用采用Native C++模板,實現使用NAPI調用C標準庫的功能。使用C標準庫hypot接口計算兩個給定數平方和的平
    的頭像 發表于 04-14 11:43 ?2765次閱讀
    鴻蒙OS開發實例:【Native <b class='flag-5'>C++</b>】

    使用 MISRA C++:2023? 避免基于范圍的 for 循環中的錯誤

    在前兩篇博客中,我們?向您介紹了新的 MISRA C++ 標準?和?C++ 的歷史?。在這篇博客中,我們將仔細研究以 C++ 中?for?循環為中心的特定規則。
    的頭像 發表于 03-28 13:53 ?861次閱讀
    使用 MISRA <b class='flag-5'>C++</b>:2023? 避免基于范圍的 for 循環中的錯誤

    為什么很少用C++開發單片機

    C語言是面向過程的語言,C++是面向對象的編程語言。結合本文來說,面向過程相比面向對象的編程,生成代碼量(bin文件)更小,運行效率更高。
    發表于 03-25 14:26 ?1142次閱讀
    為什么很少用<b class='flag-5'>C++</b>開發單片機
    大发888娱乐场 888| 现场百家乐官网的玩法技巧和规则 | 澳门博彩 | 百家乐稳赢投注| 百家乐官网娱乐注册就送| 天博百家乐的玩法技巧和规则| 百家乐官网五湖四海娱乐场| 爱玩棋牌官方下载| 百家乐扑克投注赢钱法| 钱百家乐官网取胜三步曲| 大发888娱乐城 建账号| 百家乐官网全部规则| 惠安县| 百家乐是娱乐场最不公平的游戏| 百家乐官网长龙技巧| 皇冠透注网| 百家乐游戏厅| 菲律宾百家乐官网赌场娱乐网规则| 博彩选名门国际| 百家乐学院| 最好的百家乐官网游戏平台1| bet365外围| 百家乐龙虎斗| 乐天堂百家乐官网赌场娱乐网规则 | 致胜百家乐官网的玩法技巧和规则| 新葡京线上娱乐| 试玩百家乐游戏机| 荷规则百家乐官网的玩法技巧和规则 | 网上百家乐骗人不| 百家乐官网赌机凤凰软件| 澳门顶级赌场娱乐网| 易胜博足球开户| 狮威百家乐赌场娱乐网规则| 百家乐官网实战路| 老虎机遥控器| 大发888真人真钱| 百家乐官网怎么玩| 网络百家乐官网诈骗| 注册送现金| 大发888真人真钱| 百家乐怎么看大小|