大家好,今天再次寫c++的文章,首先給各位網(wǎng)友說明一下這段時(shí)間為啥都是寫c++的文章,沒有Linux的文章;原因是這樣的,自己立了一個(gè)flag,八月份把c++的基本語(yǔ)法全部過完(目前完成三分之一),所以文章過程中我寫的可能沒有很詳細(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語(yǔ)言里面的struct關(guān)鍵字不,在之前的文章里面也學(xué)習(xí)過,使用struct關(guān)鍵字也可以來構(gòu)造類名,只不過他的所有成員都是公開的(public);換句大家好理解的話,就是結(jié)構(gòu)體,那么在c語(yǔ)言里面,const關(guān)鍵字肯定是可以修飾結(jié)構(gòu)體變量的,當(dāng)然在c++里面肯定也是可以的,c++不是取代c語(yǔ)言的,而是對(duì)c語(yǔ)言進(jìn)行擴(kuò)展著,并且兼容c語(yǔ)言的。不過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文章
517瀏覽量
44148 -
C++
+關(guān)注
關(guān)注
22文章
2114瀏覽量
73792
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論