// 派生類成員函數(shù)對基類成員函數(shù)的覆蓋
#include "stdafx.h"
#include <iostream>
class A
{
public :
void Show()
{
std::cout<< "A::Show/n" ;
}
};
class B: public A
{
public :
void Show()
{
std::cout<< "B::Show/n" ;
}
void Display()
{
Show(); // 調(diào)用派生類 B 的成員函數(shù),覆蓋掉繼承自基類的 Show() 成員方法
A::Show(); // 調(diào)用基類 A 的成員函數(shù)
}
};
int _tmain( int argc, _TCHAR* argv[])
{
A a;
B b;
a.Show();
b.Show();
b.Display();
std::cin.get();
return 0;
}
程序運行的結(jié)果:
A::Show
B::Show
B::Show
A::Show
一個派生類對象含有基類的數(shù)據(jù)成員的一個副本,在 C++ 類的多重繼承結(jié)構(gòu)中,由于多層次的交叉派生關(guān)系,一個派生類中可能保留某個基類的多個實例。例如,在下圖中, B:A,C:A,D:B,D:C, 這是在派生類 D 的對象中存在間接基類 A 的兩份副本。當(dāng)試圖通過派生類對象直接訪問基類 A 中的成員是,將會導(dǎo)致編譯二義性錯誤。
// 多重繼承的副本二義性
class A
{
public :
int a; //a
};
class B: public A
{
public :
int b; //a,b
};
class C: public A
{
public :
int c; //a,c
};
class D: public B, public C
{
public :
int d; //(a,b),(a,c),d
};
int _tmain( int argc, _TCHAR* argv[])
{
D d1;
d1.a=100; // 此處 a 具有二義性,編譯器無法確定 a 是那個副本
d1.B::a=100; // 指明訪問的是通過 B 類間接派生的
d1.C::a=100; // 指明訪問的是通過 C 類間接派生的
return 0;
}
編譯結(jié)果: error C2385: ambiguous access of 'a'
若注釋掉 d1.a=100; 則編譯通過。
在多重繼承中, C++ 提供了虛基類( virtual base class )來解決二義性的問題。虛基類只是一種派生的方式,類層次結(jié)構(gòu)中某個虛基類成員只出現(xiàn)一次,即基類的一個副本被所有派生類對象共享。修改上例代碼中 B , C 的派生方式則 d1.a=100; 是合法的。
class B: public virtual A
{
public :
int b; //a,b
};
class C: public virtual A
{
public :
int c; //a,c
};
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
