派生類的聲明:
class 派生類名:繼承方式 基類名1, 繼承方式 基類名2,...,繼承方式 基類名n
{
派生類成員聲明;
};
- 一個派生類可以同時有多個基類,這種情況稱為多重繼承。派生類隻有一個基類,稱為單繼承。慎用多繼承!
- 繼承方式規定了如何通路基類繼承的成員。繼承方式有public, private, protected。如果不顯示給出繼承方式,預設為private繼承。繼承方式指定了派生類成員以及類外對象對于從基類繼承來的成員的通路權限。
- 派生類繼承基類中除構造和析構函數以外的所有成員。
-
派生類組成:
吸收基類成員(除構造析構函數以外的所有成員);
改造基類成員(根據繼承方式調整基類成員的通路,函數在子類中的覆寫,以及虛函數在子類中的覆寫);
添加新的成員;
- 派生類中由基類繼承而來的成員的初始化工作還是由基類的構造函數完成,然後派生類中新增的成員在派生類的構造函數中初始化。
- 派生類構造函數的文法:
派生類名::派生類名(參數總表):基類1構造函數(參數表1),基類2構造函數(參數名2)....基類n構造函數(參數名n),成員屬性1構造函數(參數表1),成員屬性2構造函數(參數表2)....成員屬性n構造函數(參數表n)
{
派生類新增成員的初始化語句;
}
注:構造函數的初始化順序并不以上面的順序進行,而是根據聲明的順序初始化。
-
派生類構造函數執行的次序:
調用基類構造函數,調用順序按照它們被繼承時聲明的順序(從左到右);
調用内嵌成員對象的構造函數,調用順序按照它們在類中聲明的順序;
派生類的構造函數體中的内容。
- 派生類的析構函數的功能是在該對象消亡之前進行一些必要的清理工作,析構函數沒有類型,也沒有參數。析構函數的執行順序與構造函數相反:先是派生類的析構函數,然後是内嵌成員對象的析構函數(類中聲明順序的反序),最後是基類析構函數(從右到左)。
#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
通過上述示例,可以了解構造函數和析構函數的調用順序。
本文由部落格一文多發平台 OpenWrite 釋出!