大家好,今天再次寫(xiě)c++的文章,首先給各位網(wǎng)友說(shuō)明一下這段時(shí)間為啥都是寫(xiě)c++的文章,沒(méi)有Linux的文章;原因是這樣的,自己立了一個(gè)flag,八月份把c++的基本語(yǔ)法全部過(guò)完(目前完成三分之一),所以文章過(guò)程中我寫(xiě)的可能沒(méi)有很詳細(xì)的解釋一些概念;所以文章中有不理解的地方,可以私聊我,我會(huì)盡力解答好。同時(shí)昨天遇到一位剛高考完的網(wǎng)友,人家都這么努力學(xué)習(xí),你還打醬油嗎?
一、對(duì)象的析構(gòu)順序:
在上一篇文章里面,已經(jīng)介紹過(guò)對(duì)象的構(gòu)造順序,既然有對(duì)象的產(chǎn)生,那么就會(huì)有對(duì)象的消亡;換句話說(shuō),有資源的分配,最終系統(tǒng)就要收回這些分配出去的資源。所以也就有了對(duì)象的析構(gòu)順序用法了。下面我們來(lái)看一下對(duì)象析構(gòu)順序的分類,不過(guò)這里我們先來(lái)看構(gòu)造對(duì)象調(diào)用構(gòu)造函數(shù)的來(lái)引出對(duì)象析構(gòu)的順序:
(1)單個(gè)對(duì)象創(chuàng)建時(shí)構(gòu)造函數(shù)的調(diào)用順序:
調(diào)用父類的構(gòu)造過(guò)程(這個(gè)概念暫時(shí)還沒(méi)學(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
說(shuō)明:從運(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è)問(wèn)題答案肯定是可以修飾的,為啥這么說(shuō)呢?不知大家還是記得c語(yǔ)言里面的struct關(guān)鍵字不,在之前的文章里面也學(xué)習(xí)過(guò),使用struct關(guān)鍵字也可以來(lái)構(gòu)造類名,只不過(guò)他的所有成員都是公開(kāi)的(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ǔ)言的。不過(guò)const修飾的對(duì)象有啥特性呢?
const修飾的對(duì)象特性:
const修飾的對(duì)象為只讀對(duì)象
只讀對(duì)象的成員變量不允許被改變
只讀對(duì)象是編譯階段的概念,運(yùn)行時(shí)無(wú)效
代碼示例:
#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文章
515瀏覽量
44086 -
C++
+關(guān)注
關(guān)注
22文章
2108瀏覽量
73652
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
運(yùn)動(dòng)控制卡周期上報(bào)實(shí)時(shí)數(shù)據(jù)IO狀態(tài)之C++篇
![運(yùn)動(dòng)控制卡周期上報(bào)實(shí)時(shí)數(shù)據(jù)IO狀態(tài)<b class='flag-5'>之</b><b class='flag-5'>C++</b>篇](https://file1.elecfans.com/web3/M00/02/A2/wKgZO2dhD7aAExSYAAKMzmoxqe0256.png)
同樣是函數(shù),在C和C++中有什么區(qū)別
C語(yǔ)言中申請(qǐng)的堆內(nèi)存能不能自動(dòng)釋放
C++新手容易犯的十個(gè)編程錯(cuò)誤
C7000優(yōu)化C/C++編譯器
![<b class='flag-5'>C</b>7000優(yōu)化<b class='flag-5'>C</b>/<b class='flag-5'>C++</b>編譯器](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
基于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ù)案例:ThreadPoll
C++語(yǔ)言基礎(chǔ)知識(shí)
C++中實(shí)現(xiàn)類似instanceof的方法
![<b class='flag-5'>C++</b>中實(shí)現(xiàn)類似instanceof的方法](https://file1.elecfans.com/web2/M00/FE/0C/wKgaomaYe1CAQ31QAAAnf0IkoSU605.png)
FX2 CY7C68013A如何在C++環(huán)境中使用LoadEEPROM函數(shù)?
使用 MISRA C++:2023? 避免基于范圍的 for 循環(huán)中的錯(cuò)誤
![使用 MISRA <b class='flag-5'>C++</b>:2023? 避免基于范圍的 for 循環(huán)中的錯(cuò)誤](https://file1.elecfans.com/web2/M00/A9/66/wKgZomUl7m-AHJX6AABuJjgxs14678.png)
c語(yǔ)言,c++,java,python區(qū)別
vb語(yǔ)言和c++語(yǔ)言的區(qū)別
C++簡(jiǎn)史:C++是如何開(kāi)始的
![<b class='flag-5'>C++</b>簡(jiǎn)史:<b class='flag-5'>C++</b>是如何開(kāi)始的](https://file1.elecfans.com/web2/M00/A9/66/wKgZomUl7m-AHJX6AABuJjgxs14678.png)
評(píng)論