看一个例子:
class Base {
public:
virtual void mf1() = 0;
virtual void mf1(int){}
virtual void mf2(){}
void mf3(){}
void mf3(double){}
};
class Derived: public Base {
public:
virtual void mf1(){}
void mf3(){}
void mf4(){}
};
这段代码带来的行为会让每一位第一次面对它的c++程序员大吃一惊,base class 内所有名为mf1各mf3的函数都被derived class内的mf1和mf3函数遮掩掉了。从名称查找观点来看,Base::mf1和Base::mf3不再被Derived继承!
Derived d;
int x;
d.mf1();
d.mf1(x); //错误!因为Derived::mf3遮掩了Base::mf1
d.mf2();
d.mf3();
d.mf3(x); //错误!因为Derived::mf3遮掩了Base::mf3
上述行为违反base和derived class之间的is-a关系,因此你几乎总会要推翻c++对“继承而来的名称”的缺省遮掩行为。可以使用using声明式达成目标:
class Derived: public Base {
public:
using Base::mf1; //让Base class内名为mf1和mf3的
using Base::mf3; //所有东西在Derived作用域内都可见
virtual void mf1(){}
void mf3(){}
void mf4(){}
};
注:
以c++进行面向对象编程,最重要的一个规则是:public inheritance(公开继承)意味着“is-a”(是一种)的关系。