參考資料:《C++Primer(第5版 )》
練習目的:虛函數與作用域。
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;
class Base {
public:
virtual int fun() {return 12;}//虛函數;
};
class D1 : public Base {
public:
int fun(int a) {return 10;}//隱藏基類的fun(), 它不是虛函數;
//D1繼承了Base::fun()的定義;
virtual void f2() {cout << "ans" << endl;}//是一個新的虛函數, 在Base中不存在;
};
class D2 : public D1 {
public:
int fun(int a) {return 15;}//是一個非虛函數, 隱藏了D1::fun(int);
int fun() {return 20;}//覆蓋了Base的虛函數fun();
void f2() {cout << "ans1" << endl;}//覆蓋了D1的虛函數f2();
};
int main() {
ios::sync_with_stdio(false);
cin.tie(NULL);
Base bobj;
D1 d1obj;
D2 d2obj;
Base *bp1 = &bobj, *bp2 = &d1obj, *bp3 = &d2obj;
cout << bp1 -> fun() << endl;//12;//調用Base::fun();//編譯器產生的代碼將在運行時確定使用虛函數的哪個版本;
cout << bp2 -> fun() << endl;//12;//調用Base::fun();//它隱藏了Base::fun(), 沒有覆蓋;
cout << bp3 -> fun() << endl;//20;//調用D2::fun();//動態綁定, 調用D2的版本(它覆蓋了Base::fun());
D1 *d1p = &d1obj;
D2 *d2p = &d2obj;
//bp2 -> f2();//錯誤, Base沒有名為f2的成員函數;
d1p -> f2();//ans;//虛調用;
d2p -> f2();//ans1;//虛調用;
//對于非虛函數fun(int)的調用語句;
Base *p1 = &d2obj;//每一個指針都指向了D2類型的對象;
D1 *p2 = &d2obj;
D2 *p3 = &d2obj;
//cout << p1 -> fun(42) << endl;//錯誤, Base中沒有接受一個int的fun;
cout << p2 -> fun(42) << endl;//靜態綁定, 調用D1::fun(int);//10;
cout << p3 -> fun(42) << endl;//靜態綁定, 調用D2::fun(int);//15;
return 0;
}