問題:如下代碼輸出結(jié)果是垦写?
#include<iostream>
using namespace std;
class A {
protected:
????int m_data;
public:
????A(int data = 0) { m_data = data; }
????int GetData() { return doGetData(); }
????virtual int doGetData() { return m_data; }
};class B : public A {
protected:
????int m_data;
public:
????B(int data = 1) { m_data = data; }
????int doGetData() { return m_data; }
};
class C : public B {
protected:
????int m_data;
public:
????C(int data = 2) { m_data = data; }
};
int main ()
{
????C c(10);
????cout << c.GetData() <<endl;?
????cout << c.A::GetData() <<endl;
????cout << c.B::GetData() <<endl;
????cout << c.C::GetData() <<endl;
????cout << c.doGetData() <<endl;
? ? cout << c.A::doGetData() <<endl;
? ? cout << c.B::doGetData() <<endl;
? ? cout << c.C::doGetData() <<endl;
? ? return 0违柏;
}
解析:輸出結(jié)果是:
其它的都比較好理解唆铐,這里不贅述慢叨,主要是解答以下為啥第2個cout和第6個cout結(jié)果不一樣。
cout << c.A::GetData() <<endl;? ? ? ? // 1
cout << c.A::doGetData() <<endl;? ? // 0
這里兩個盡管都是調(diào)用A類中的函數(shù)恼蓬,可是:一個是成員函數(shù)調(diào)用虛函數(shù)阿趁,一個是直接調(diào)用虛函數(shù);
第一個函數(shù)是成員函數(shù)調(diào)用虛函數(shù)瀑志,本類(C類)中無該虛函數(shù)的定義聲明涩搓。故找到最近的基類系(B類)虛函數(shù);
第二個函數(shù)直接調(diào)用虛函數(shù)劈猪,直接去調(diào)用類(A類)中查找昧甘。故找到調(diào)用類結(jié)果就可以,找不到就編譯失斦降谩(比如A類的doGetData如果是純虛函數(shù)就會編譯失敵浔摺)。
如果說:cout << c.A::doGetData() <<endl; 還是會走到B類的doGetData()函數(shù)常侦。那么請想一下這個問題:
cout << c.A::doGetData() <<endl; 還是會走到B類的doGetData()函數(shù)浇冰,那么上圖2中的B類的Print()函數(shù)就不能調(diào)A::Print()函數(shù),因為一旦允許這種寫法聋亡,那么b.A::Print()這個調(diào)用必然是死循環(huán)肘习。
詳細(xì)解答參考:
C++ 繼承與接口 知識點 小結(jié)(一)-CSDN博客
https://blog.csdn.net/weixin_33743248/article/details/85889749