大家好,今天再次寫c++的文章,首先給各位網(wǎng)友說明一下這段時間為啥都是寫c++的文章,沒有Linux的文章;原因是這樣的,自己立了一個flag,八月份把c++的基本語法全部過完(目前完成三分之一),所以文章過程中我寫的可能沒有很詳細的解釋一些概念;所以文章中有不理解的地方,可以私聊我,我會盡力解答好。同時昨天遇到一位剛高考完的網(wǎng)友,人家都這么努力學(xué)習(xí),你還打醬油嗎?
一、對象的析構(gòu)順序:
在上一篇文章里面,已經(jīng)介紹過對象的構(gòu)造順序,既然有對象的產(chǎn)生,那么就會有對象的消亡;換句話說,有資源的分配,最終系統(tǒng)就要收回這些分配出去的資源。所以也就有了對象的析構(gòu)順序用法了。下面我們來看一下對象析構(gòu)順序的分類,不過這里我們先來看構(gòu)造對象調(diào)用構(gòu)造函數(shù)的來引出對象析構(gòu)的順序:
(1)單個對象創(chuàng)建時構(gòu)造函數(shù)的調(diào)用順序:
調(diào)用父類的構(gòu)造過程(這個概念暫時還沒學(xué),先不用管)
調(diào)用成員變量的構(gòu)造函數(shù)(調(diào)用順序與聲明順序相同)
調(diào)用類自身的構(gòu)造函數(shù)
引出:析構(gòu)函數(shù)與對應(yīng)的構(gòu)造函數(shù)的調(diào)用順序相反,也就是對象構(gòu)造與對象析構(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
說明:從運行結(jié)果,我們可以看到先觸發(fā)全局對象的構(gòu)造函數(shù),然后是觸發(fā)初類Test2里面的mA和mB對象的構(gòu)造函數(shù),最后觸發(fā)局部對象的構(gòu)造函數(shù),然后進行析構(gòu),我們可以看到,析構(gòu)順序完全和構(gòu)造順序相反。非常類似于棧的操作規(guī)則,棧是先入棧,卻是最后出棧。
二、const關(guān)鍵字可以修飾類的對象嘛?
1、這個問題答案肯定是可以修飾的,為啥這么說呢?不知大家還是記得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語言的,而是對c語言進行擴展著,并且兼容c語言的。不過const修飾的對象有啥特性呢?
const修飾的對象特性:
const修飾的對象為只讀對象
只讀對象的成員變量不允許被改變
只讀對象是編譯階段的概念,運行時無效
代碼示例:
#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;}
運行結(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是不能修改的,為只讀的,因為類對象被const修飾了。
-
可編程邏輯
+關(guān)注
關(guān)注
7文章
524瀏覽量
44654 -
C++
+關(guān)注
關(guān)注
22文章
2118瀏覽量
74961
發(fā)布評論請先 登錄
在OpenVINO? C++代碼中啟用 AddressSanitizer 時的內(nèi)存泄漏怎么解決?
基于LockAI視覺識別模塊:C++目標檢測

Spire.XLS for C++組件說明

同樣是函數(shù),在C和C++中有什么區(qū)別
C語言中申請的堆內(nèi)存能不能自動釋放
C++新手容易犯的十個編程錯誤
基于OpenHarmony標準系統(tǒng)的C++公共基礎(chǔ)類庫案例:SafeStack
基于OpenHarmony標準系統(tǒng)的C++公共基礎(chǔ)類庫案例:SafeQueue
基于OpenHarmony標準系統(tǒng)的C++公共基礎(chǔ)類庫案例:rwlock
基于OpenHarmony標準系統(tǒng)的C++公共基礎(chǔ)類庫案例:ThreadPoll
C++中實現(xiàn)類似instanceof的方法

評論