C++類成員構造函數(shù)和析構函數(shù)順序示例詳細講解
對象并不是突然建立起來的,創(chuàng)建對象必須時必須同時創(chuàng)建父類以及包含于其中的對象。C++遵循如下的創(chuàng)建順序:
(1)如果某個類具體基類,執(zhí)行基類的默認構造函數(shù)。
(2)類的非靜態(tài)數(shù)據(jù)成員,按照聲明的順序創(chuàng)建。
(3)執(zhí)行該類的構造函數(shù)。
即構造類時,會先構造其父類,然后創(chuàng)建類成員,最后調(diào)用本身的構造函數(shù)。
下面看一個例子吧
class c
{
public:
c(){ printf("c\n"); }
protected:
private:
};
class b
{
public:
b(){ printf("b\n");}
protected:
c C;
private:
};
class a : public b
{
public:
a(){ printf("a\n"); }
protected:
private:
};
int main()
{
a A;
getchar();
}

分析一下吧 首先定義了3個類 a b c,其中a繼承自b ,在main函數(shù)里面構造a ,因為a是繼承b ,所以會先構造b,然后b類又有一個成員c類,所以c類是最先構造的,然后是b ,最后才是a。
在看一個例子,就是上面的該了一下:
class c
{
public:
c(){ printf("c\n"); }
protected:
private:
};
class b
{
public:
b(){ printf("b\n");}
protected:
private:
};
class a : public b
{
public:
a(){ printf("a\n"); }
protected:
c C;
private:
};
int main()
{
a A;
getchar();
}
沒有改變多少,只是在a添加了c成員,而b去掉了。
同樣是在main里面構造a ,a繼承自b,所以先構造b,然后構造a本身的數(shù)據(jù)成員c,最后才調(diào)用的a本身的構造函數(shù)。。
這里大家應該明白構造的細節(jié)了吧 。。
接下來看析構的順序:
(1)調(diào)用類的析構函數(shù)。
(2)銷毀數(shù)據(jù)成員,與創(chuàng)建的順序相反。
(3)如果有父類,調(diào)用父類的析構函數(shù)。
也看一個例子吧:
class c
{
public:
c(){}
~c(){ printf("c\n"); }
protected:
private:
};
class b
{
public:
b(){}
~b(){ printf("b\n");}
protected:
private:
};
class a : public b
{
public:
a(){}
~a(){ printf("a\n"); }
protected:
c C;
private:
};
int main()
{
a A;
return 0;
}

其過程是,在main函數(shù)結(jié)束時,會銷毀a,就會先調(diào)用a的析構函數(shù),先后銷毀a的數(shù)據(jù)成員c,最后銷毀a的父類b。其實就是跟創(chuàng)建時的順序反了過來。
好了,到這里相信大家已經(jīng)明白構造析構的奧秘了吧!
相關文章
C語言實現(xiàn)輸入兩個數(shù)字將其按從小到大輸出的方法
這篇文章主要介紹了C語言實現(xiàn)輸入兩個數(shù)字將其按從小到大輸出的方法,本文通過代碼講解的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04C++實現(xiàn)LeetCode(76.最小窗口子串)
這篇文章主要介紹了C++實現(xiàn)LeetCode(76.最小窗口子串),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07QT中QTableWidget加載大量數(shù)據(jù)不卡頓的解決
本文主要介紹了QT中QTableWidget加載大量數(shù)據(jù)不卡頓的解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07C語言實現(xiàn)交換排序算法(冒泡,快速排序)的示例代碼
這篇文章主要為大家詳細介紹了如何利用C語言實現(xiàn)交換排序算法(冒泡排序、快速排序),文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下2022-07-07