c++成员函数的重载、覆盖和隐藏很容易混淆,所以咱们必须搞清楚这一点。ios
重载特色:同一访问区域(同类)、函数名称相同、函数参数不一样(不关心返回类型)、virtual关键字无关紧要。c++
代码示例:函数
class OverLoad { public: void test() {} void test(int i) {} void test(float i) {} void test(int i, float j) {} };
覆盖是指派生类函数覆盖基类函数,特色是:不一样访问区域(不一样类)、函数名称相同 、参数相同、基类函数必须有virtual关键字。spa
隐藏规则:3d
1) 若是派生类的函数与基类的函数同名,可是参数不一样。此时,不论有无virtual关键字,基类的函数将被隐藏。 code
2) 若是派生类的函数与基类的函数同名,而且参数也相同,可是基类函数没有virtual关键字。此时,基类的函数被隐藏。 blog
#include <iostream> using namespace std; class OverLoad { public: void test() {} void test(int i) {} void test(float i) {} void test(int i, float j) {} }; class Base { public: virtual void A(int i) { cout << "Base::A()" << endl; } void B(int i) { cout << "Base::B()" << endl; } void C(int i) { cout << "Base::C()" << endl; } void D() { cout << "Base::D()" << endl; } }; class Derive : public Base { public: //覆盖父类的A 函数名、参数彻底相同,且父类要有virtual,子类virtual无关紧要 virtual void A(int i) { cout << "Derive::A()" << endl; } //隐藏父类中的B 函数名、参数彻底相同,父类无virtual void B(int i) { cout << "Derive::B()" << endl; } //隐藏父类中的C 函数名相同、参数不一样,与virtual无关 void C(char* str) { cout << "Derive::C()" << endl; } }; int main() { Derive* d = new Derive; Base* b = d; //均调用父类中的A d->A(1); b->A(2); //分别调用本身的B d->B(1); b->B(1); //分别调用本身的C d->C("1"); b->C(1); d->D();//未被隐藏能够调用D() //d->C(1);因为隐藏了父类中的void C(int i),因此不能再调用 }