大家好,今天再次寫c++的文章,首先給各位網友說明一下這段時間為啥都是寫c++的文章,沒有Linux的文章;原因是這樣的,自己立了一個flag,八月份把c++的基本語法全部過完(目前完成三分之一),所以文章過程中我寫的可能沒有很詳細的解釋一些概念;所以文章中有不理解的地方,可以私聊我,我會盡力解答好。同時昨天遇到一位剛高考完的網友,人家都這么努力學習,你還打醬油嗎?
一、對象的析構順序:
在上一篇文章里面,已經介紹過對象的構造順序,既然有對象的產生,那么就會有對象的消亡;換句話說,有資源的分配,最終系統就要收回這些分配出去的資源。所以也就有了對象的析構順序用法了。下面我們來看一下對象析構順序的分類,不過這里我們先來看構造對象調用構造函數的來引出對象析構的順序:
(1)單個對象創建時構造函數的調用順序:
調用父類的構造過程(這個概念暫時還沒學,先不用管)
調用成員變量的構造函數(調用順序與聲明順序相同)
調用類自身的構造函數
引出:析構函數與對應的構造函數的調用順序相反,也就是對象構造與對象析構(消亡)的順序相反。
(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;}
演示結果:
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
說明:從運行結果,我們可以看到先觸發全局對象的構造函數,然后是觸發初類Test2里面的mA和mB對象的構造函數,最后觸發局部對象的構造函數,然后進行析構,我們可以看到,析構順序完全和構造順序相反。非常類似于棧的操作規則,棧是先入棧,卻是最后出棧。
二、const關鍵字可以修飾類的對象嘛?
1、這個問題答案肯定是可以修飾的,為啥這么說呢?不知大家還是記得c語言里面的struct關鍵字不,在之前的文章里面也學習過,使用struct關鍵字也可以來構造類名,只不過他的所有成員都是公開的(public);換句大家好理解的話,就是結構體,那么在c語言里面,const關鍵字肯定是可以修飾結構體變量的,當然在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;}
運行結果:
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修飾了。
-
可編程邏輯
+關注
關注
7文章
526瀏覽量
44579 -
C++
+關注
關注
22文章
2117瀏覽量
74783
發布評論請先 登錄
基于LockAI視覺識別模塊:C++目標檢測
基于LockAI視覺識別模塊:C++目標檢測

Spire.XLS for C++組件說明

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

評論