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

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

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

#include

using namespace std;

class Base

{

public:

void fun(int data)

{

cout<

}

};

class Derivd:public Base

{

public:

using Base::fun;

void fun(double data)

{

cout<

}

};

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的作用域拓展到子类

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值