继承中的遮掩问题

来源:岁月联盟 编辑:exp 时间:2012-11-01

继承中的遮掩问题

以作用域为基础的“名称遮掩规则”同样适用于类的继承。而且不论函数是virtual或non-virtual都一体适用。
事例:
Derived class 内的名称会遮掩 Base class 内的名称。

class Base
{
private:
 int x;
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();
};

Derived d;
int x;

d.mf1();   //没问题,调用Derived::mf1;
d.mf1(x);  //错误,因为Derived::mf1遮掩了Base::mf1
d.mf2();   //没问题,调用Base::mf2
d.mf3();   //没问题,调用Derived::mf3
d.mf3(x)       //错误,因为Derived::mf3遮掩了Base::mf3

为了让遮掩的名称再见天日,可使用using 声明式或转交函数。
事例:
使用using声明式解决遮掩问题。

class Derived: public Base
{
public:
 using Base::mf1;   //让Base class 内名为mf1和mf3的所有东西
 using Base::mf3;   //在Derived 作用域内都可见。
 virtual void mf1();
 void mf3();
 void mf4();
};

Derived d;
int x;

d.mf1();   //没问题,调用Derived::mf1;
d.mf1(x);  //现在没问题了,调用Base::mf1
d.mf2();   //没问题,调用Base::mf2
d.mf3();   //没问题,调用Derived::mf3
d.mf3(x)       //现在没问题了,调用Base::mf3


使用 using 声明还可以做到在Derived类中重载Base类中的函数(别忘了,原来意义的重载只可以重载当前类中的函数)。