派生類的聲明:ios
class 派生類名:繼承方式 基類名1, 繼承方式 基類名2,...,繼承方式 基類名n {
派生類成員聲明;
};
複製代碼
派生類名::派生類名(參數總表):基類1構造函數(參數表1),基類2構造函數(參數名2)....基類n構造函數(參數名n),成員屬性1構造函數(參數表1),成員屬性2構造函數(參數表2)....成員屬性n構造函數(參數表n)
{
派生類新增成員的初始化語句;
}
注:構造函數的初始化順序並不以上面的順序進行,而是根據聲明的順序初始化。
複製代碼
派生類構造函數執行的次序: 調用基類構造函數,調用順序按照它們被繼承時聲明的順序(從左到右); 調用內嵌成員對象的構造函數,調用順序按照它們在類中聲明的順序; 派生類的構造函數體中的內容。函數
派生類的析構函數的功能是在該對象消亡以前進行一些必要的清理工做,析構函數沒有類型,也沒有參數。析構函數的執行順序與構造函數相反:先是派生類的析構函數,而後是內嵌成員對象的析構函數(類中聲明順序的反序),最後是基類析構函數(從右到左)。ui
#include <iostream>
#include <time.h>
using namespace std;
class B1 {
public:
B1(int i)
{
cout<<"constructing B1 "<<i<<endl;
}
~B1()
{
cout<<"destructing B1"<<endl;
}
};
class B2 {
public:
B2(int j)
{
cout<<"constructing B2 "<<j<<endl;
}
~B2()
{
cout<<"destructing B2"<<endl;
}
};
class B3 {
public:
B3()
{
cout<<"constructing B3"<<endl;
}
~B3()
{
cout<<"destructing B3"<<endl;
}
};
class C: public B2, public B1, public B3
{
public:
C(int a, int b, int c, int d):B1(a), memberB2(d), memberB1(c),B2(b)
{
}
private:
B1 memberB1;
B2 memberB2;
B3 memberB3;
};
int main() {
C obj(1,2,3,4);
return 0;
}
輸出結果爲:
constructing B2 2
constructing B1 1
constructing B3
constructing B1 3
constructing B2 4
constructing B3
destructing B3
destructing B2
destructing B1
destructing B3
destructing B1
destructing B2
複製代碼
經過上述示例,能夠理解構造函數和析構函數的調用順序。spa