派生类函数与基类函数同名,则会覆盖基类的函数调用,如下。
class Base{
private:
int x;
public :
virtural void mf1()=0;
virtural void mf1(int);
virtual void mf2();
void mf3();
void mf3(double);
}
class Drived:public Base{
public:
virtual void mf1();
void mf3();
void mf4();
}
此时派生类覆盖了基类的mf1,mf3,如果有一下操作:
Drived d;
int x;
d.mf1();//没问题 调用派生类的mf1
d.mf1(x);//出错,因为Drived::mf1遮盖了Base::mf1
d.mf2();//没问题,调用base的mf2
d.mf3();//没问题,调用drived的mf3
d.mf3(x);//错误,遮盖了基类的mf3;
派生类想要调用基类的函数使用using来声明基类。派生类修改如下:
class Drived:public Base{
public:
using Base::mf1;
using Base::mf3;//声明基类函数,让其在派生类的作用域可见,不需要参数
virtual void mf1();
void mf3();
void mf4();
}
此时再次调用上面的代码全部都能通过使用。
或者可以使用转交函数如:
class Drived:public Base{
public:
virtual void mf1()
{
Base::mf1();//转交函数,暗自成为inline
};
void mf3();
void mf4();
}
此时还是只能调用d.mf1();//虽然调用的是drived的mf1 但是通过转交。实际调用的base的mf1