通过使用using 子类重载父类方法

转自:https://blog.csdn.net/bama2488313716/article/details/51704944

使用using 申明式可以使得父类中的同名函数在子类中可见,从而实现函数重载。实现代码如下所示:

#include <iostream>
using namespace std;

class Base
{
public:
void fun(int data)
{
cout<<"int"<<endl;
}
};

class Derivd:public Base
{
public:
using Base::fun;
void fun(double data)
{
cout<<"double"<<endl;
}
};

int main()
{
Derivd d;
d.fun(12);
}

这里using申明式可以使得父类中被遮掩住的同名函数在子类中可见,从而在子类中实现函数重载。

转自:https://blog.csdn.net/aa13058219642/article/details/51842745

其实,并没有‘子类“重载”父类的方法’这种说法。

《C++Primer Plus》 中说道:

  • 如果基类声明被重载了,则应该在派生类中重新定义所有的基类版本。
  • 如果在派生类中只重新定义一个版本,其他版本将会被隐藏,派生类对象将无法使用它们。

简而言之,重新定义函数,并不是重载。在派生类中定义函数,将不是使用相同的函数特征标覆盖基类声明,而是隐藏同名的基类方法,不管参数的特征标如何。

举例:

    class A{
        virtual print(void);
        virtual print(int a);
    }

    class B : public A{
        virtual print(float a);
    }

    int main(){
        B* b = new B();
        b->print(); //这里会报参数过少的错误
    }

如同《C++Primer Plus》 中说的,B类重新定义了print(float a),所以A类定义的两个print都被隐藏无法使用了

但是有时我们确实有这样的需求,父类的提供的方法重载不能满足我们的要求,我们要在子类拓展该方法,但是我们又不想全部重写,那这时改怎么办呢?

加一句话:using A::print;

    class A{
    public:
        virtual print(void);
        virtual print(int a);
    }

    class B : public A{
    public:
        using A::print; //<======加这一句
        virtual print(float a);
    }

    int main(){
        B* b = new B();
        b->print(); //这里就可以用了
    }

这句话的作用,其实就是把父类print的作用域拓展到子类

所以说,这种做法正确的说法应该是:子类扩展父类的方法 ….大概吧

原文地址:https://www.cnblogs.com/loveSH/p/9685991.html