这一章一直在想怎么写,因为比较基础,很容易理解,就按照需要来写吧。

假设我们有这样一个类:

 class Base {
private:
int x;
public:
virtual void mf1() = ;
virtual void mf2();
void mf3(); }; class Derived : public Base {
public:
virtual void mf1();
void mf4();
};

如果mf4()的实现代码为:

 void Derived::mf4(){
mf2();
}

在查找mf2()函数的过程中,先找mf4的函数作用域,在查找Derived类作用域,再查找Base类。

然后更改:

 class Base {
private:
int x;
public:
virtual void mf1() = ;
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();
d.mf1(x); //错误,Derived::mf1遮掩了Base::mf1
d.mf2();
d.mf3();
d.mf3(x); //错误,Derived::mf3遮掩了Base::mf3

我们可以使用using声明式达成目标:

 class Derived : public Base {
public: //base class内的public名称在publicly derived class内也应该是public。
using Base::mf1; // 让base class内为mf1和mf3的所有东西
using Base::mf3; //在Derived class作用域内都可见(并且public)
virtual void mf1();
void mf3();
void mf4();
}; Derived d;
int x;
d.mf1();
d.mf1(x);//现在没问题了,调用Base::mf1
d.mf2();
d.mf3();
d.mf3(x);//现在没问题了,调用Base::mf3

或者:

 class Derived : private Base {
public:
virtual void mf1()//转交函数
{
Base::mf1();//暗自转成inline (条款30)
} …
};

◆总结

1.derived class内的名称会遮掩base class内的名称。在public继承下从来没有人希望如此。

2.为了让被遮掩的名称重见天日,可以使用using声明式或转交函数。

04-20 11:52