大家好,今天再次寫c++的文章,首先給各位網(wǎng)友說明一下這段時(shí)間為啥都是寫c++的文章,沒有Linux的文章;原因是這樣的,自己立了一個(gè)flag,八月份把c++的基本語法全部過完(目前完成三分之一),所以文章過程中我寫的可能沒有很詳細(xì)的解釋一些概念;所以文章中有不理解的地方,可以私聊我,我會(huì)盡力解答好。同時(shí)昨天遇到一位剛高考完的網(wǎng)友,人家都這么努力學(xué)習(xí),你還打醬油嗎?
一、對(duì)象的析構(gòu)順序:
在上一篇文章里面,已經(jīng)介紹過對(duì)象的構(gòu)造順序,既然有對(duì)象的產(chǎn)生,那么就會(huì)有對(duì)象的消亡;換句話說,有資源的分配,最終系統(tǒng)就要收回這些分配出去的資源。所以也就有了對(duì)象的析構(gòu)順序用法了。下面我們來看一下對(duì)象析構(gòu)順序的分類,不過這里我們先來看構(gòu)造對(duì)象調(diào)用構(gòu)造函數(shù)的來引出對(duì)象析構(gòu)的順序:
(1)單個(gè)對(duì)象創(chuàng)建時(shí)構(gòu)造函數(shù)的調(diào)用順序:
調(diào)用父類的構(gòu)造過程(這個(gè)概念暫時(shí)還沒學(xué),先不用管)
調(diào)用成員變量的構(gòu)造函數(shù)(調(diào)用順序與聲明順序相同)
調(diào)用類自身的構(gòu)造函數(shù)
引出:析構(gòu)函數(shù)與對(duì)應(yīng)的構(gòu)造函數(shù)的調(diào)用順序相反,也就是對(duì)象構(gòu)造與對(duì)象析構(gòu)(消亡)的順序相反。
(2)代碼演示:
#include <stdio.h>
class Test{ const char * i; public: Test(const char *s) { printf("Test(const char *s) is %s",s); i=s; } ~Test() { printf("~Test() is %s",i); }};
class Test2{ Test mA; Test mB; public: Test2():mB("mB"),mA("mA") { printf("Test2()"); } ~Test2() { printf("~Test2()"); }};
Test gA("gA");
int main(){ Test2 t;
return 0;}
演示結(jié)果:
Test(const char *s) is gATest(const char *s) is mATest(const char *s) is mBTest2()~Test2()~Test() is mB~Test() is mA~Test() is gA
說明:從運(yùn)行結(jié)果,我們可以看到先觸發(fā)全局對(duì)象的構(gòu)造函數(shù),然后是觸發(fā)初類Test2里面的mA和mB對(duì)象的構(gòu)造函數(shù),最后觸發(fā)局部對(duì)象的構(gòu)造函數(shù),然后進(jìn)行析構(gòu),我們可以看到,析構(gòu)順序完全和構(gòu)造順序相反。非常類似于棧的操作規(guī)則,棧是先入棧,卻是最后出棧。
二、const關(guān)鍵字可以修飾類的對(duì)象嘛?
1、這個(gè)問題答案肯定是可以修飾的,為啥這么說呢?不知大家還是記得c語言里面的struct關(guān)鍵字不,在之前的文章里面也學(xué)習(xí)過,使用struct關(guān)鍵字也可以來構(gòu)造類名,只不過他的所有成員都是公開的(public);換句大家好理解的話,就是結(jié)構(gòu)體,那么在c語言里面,const關(guān)鍵字肯定是可以修飾結(jié)構(gòu)體變量的,當(dāng)然在c++里面肯定也是可以的,c++不是取代c語言的,而是對(duì)c語言進(jìn)行擴(kuò)展著,并且兼容c語言的。不過const修飾的對(duì)象有啥特性呢?
const修飾的對(duì)象特性:
const修飾的對(duì)象為只讀對(duì)象
只讀對(duì)象的成員變量不允許被改變
只讀對(duì)象是編譯階段的概念,運(yùn)行時(shí)無效
代碼示例:
#include <stdio.h>
class Test{ int mi;public: int mj; Test(int i); Test(const Test& t); int getMi();};
Test::Test(int i){ mi = i;}
Test::Test(const Test& t){
}
int Test::getMi(){ return mi;}
int main(){
const Test t1(1);
t1.mj = 100; printf("the t1.mj is %d",t1.mj);
return 0;}
運(yùn)行結(jié)果:
test.cpp: In function ‘int main()’:test.cpp:34:10: error: assignment of member ‘Test::mj’ in read-only object t1.mj = 100;
分析:我們可以看出public里面的屬性mj是不能修改的,為只讀的,因?yàn)轭悓?duì)象被const修飾了。
-
可編程邏輯
+關(guān)注
關(guān)注
7文章
526瀏覽量
44756 -
C++
+關(guān)注
關(guān)注
22文章
2119瀏覽量
75289
發(fā)布評(píng)論請(qǐng)先 登錄
在OpenVINO? C++代碼中啟用 AddressSanitizer 時(shí)的內(nèi)存泄漏怎么解決?
基于LockAI視覺識(shí)別模塊:C++目標(biāo)檢測(cè)

Spire.XLS for C++組件說明

運(yùn)動(dòng)控制卡周期上報(bào)實(shí)時(shí)數(shù)據(jù)IO狀態(tài)之C++篇

同樣是函數(shù),在C和C++中有什么區(qū)別
C語言中申請(qǐng)的堆內(nèi)存能不能自動(dòng)釋放
C++新手容易犯的十個(gè)編程錯(cuò)誤
C7000優(yōu)化C/C++編譯器

基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)的C++公共基礎(chǔ)類庫(kù)案例:SafeStack
基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)的C++公共基礎(chǔ)類庫(kù)案例:SafeQueue
基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)的C++公共基礎(chǔ)類庫(kù)案例:rwlock
基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)的C++公共基礎(chǔ)類庫(kù)案例:ThreadPoll
C++語言基礎(chǔ)知識(shí)
C++中實(shí)現(xiàn)類似instanceof的方法

評(píng)論