c++之虚基类初始化
C++虛基類構(gòu)造函數(shù)
下面文章詳細(xì)介紹C++虛基,所謂C++虛基類:是由最派生類的構(gòu)造函數(shù)通過調(diào)用虛基類的構(gòu)造函數(shù)進(jìn)行初始化的,但前提是要深入理解到底什么是C++虛基類,及他是怎么運(yùn)行的。
前面講過,為了初始化基類的子對(duì)象,派生類的構(gòu)造函數(shù)要調(diào)用基類的構(gòu)造函數(shù)。對(duì)于虛基類來(lái)講,由于派生類的對(duì)象中只有一個(gè)虛基類子對(duì)象。為保證虛基類子對(duì)象只被初始化一次,這個(gè)虛基類構(gòu)造函數(shù)必須只被調(diào)用一次(考慮多重繼承)。
由于繼承結(jié)構(gòu)的層次可能很深,規(guī)定將在建立對(duì)象時(shí)所指定的類稱為最派生類。C++規(guī)定,虛基類子對(duì)象是由最派生類的構(gòu)造函數(shù)通過調(diào)用虛基類的構(gòu)造函數(shù)進(jìn)行初始化的。如果一個(gè)派生類有一個(gè)直接或間接的C++虛基類,那么派生類的構(gòu)造函數(shù)的成員初始列表中必須列出對(duì)虛基類構(gòu)造函數(shù)的調(diào)用。如果未被列出,則表示使用該虛基類的缺省構(gòu)造函數(shù)來(lái)初始化派生類對(duì)象中的虛基類子對(duì)象。
從虛基類直接或間接繼承的派生類中的構(gòu)造函數(shù)的成員初始化列表中都要列出這個(gè)虛基類構(gòu)造函數(shù)的調(diào)用。但是,只有用于建立對(duì)象的那個(gè)最派生類的構(gòu)造函數(shù)調(diào)用虛基類的構(gòu)造函數(shù)。
而該派生類的基類中所列出的對(duì)這個(gè)虛基類的構(gòu)造函數(shù)調(diào)用在執(zhí)行中被忽略,這樣便保證了對(duì)虛基類的對(duì)象只初始化一次。C++又規(guī)定,在一個(gè)成員初始化列表中出現(xiàn)對(duì)虛基類和非虛基類構(gòu)造函數(shù)的調(diào)用,則C++虛基類的構(gòu)造函數(shù)先于非虛基類的構(gòu)造函數(shù)的執(zhí)行。
class A
{
public:
A(const char *s)
{
cout << s << endl;
}
};
class B : virtual public A
{
public:
B(const char *s1, const char *s2) :A(s1) { cout << s2 << endl; }
};
class C : virtual public A
{
public: C(const char *s1, const char *s2) :A(s1) { cout << s2 << endl; }
};
class D : public B, public C
{
public: D(const char *s1, const char *s2, const char *s3, const char *s4) :B(s1, s2), C(s1, s3), A(s1)
{
cout << s4 << endl;
}
};
/*
輸出:
class A
class B
class C
class D
*/
int main()
{
D *ptr = new D("class A", "class B", "class C", "class D");
delete ptr;
ptr = NULL;
system("pause");
return 0;
}
在派生類B和C中使用了C++虛基類,使得建立的D類對(duì)象只有一個(gè)虛基類子對(duì)象。在派生類B,C,D的構(gòu)造函數(shù)的成員初始化列表中都包含了虛基類A的構(gòu)造函數(shù)。在建立類D對(duì)象時(shí)只有D的構(gòu)造函數(shù)的成員初始化列表中列出的虛基類構(gòu)造函數(shù)被調(diào)用,并且僅調(diào)用一次,而類D的基類(B、C)的構(gòu)造函數(shù)的成員初始化列表中列出的虛基類構(gòu)造函數(shù)不被執(zhí)行。這一點(diǎn)將從該程序的輸出結(jié)果可以看出。
總結(jié)
以上是生活随笔為你收集整理的c++之虚基类初始化的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SAP CRM产品主数据明细页面无法打开
- 下一篇: implode