c派生类中如何实现重载父类的特定方法?

2026-04-28 03:431阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计583个文字,预计阅读时间需要3分钟。

c派生类中如何实现重载父类的特定方法?

我遇到以下问题:假设有基类A的方法:A operator+(A a){...},我还有一个派生类B,它重载了这个方法:B operator+(B b){...}。问题是:如果我想要打电话给b+a(其中b是B类型,A类型是A的子类),我该怎么做?

我有以下问题:

假设基类A的方法:

A& operator+(A& a) {...}

我还有一个派生类B,它重载(或至少应该这样)这个方法:

A& operator+(B& b) {...}

问题是如果我想打电话给:
b a(其中b是B类型,A类型是A)我得到编译错误.
(错误C2679:二进制”:找不到带有’A’类型右手操作数的运算符(或者没有可接受的转换)).

不应该调用基类方法吗? (看起来它覆盖了方法..)
如果没有,为什么?有没有办法解决这个问题(不要告诉我用B&A重载B中的方法)

对不起,我不提供格式化文本的例子,但我不知道如何格式化它.

提前致谢!

PS Im使用Visual Studio 2010测试版.

不,它不会调用基类函数. B类有一个操作符,它没有采用正确的参数,故事结束.

您可以将运算符定义为自由函数,而不是任何类.也许是朋友,如果需要访问私人数据:

c派生类中如何实现重载父类的特定方法?

A operator+(const A &lhs, const A &rhs) { ... } B operator+(const B &lhs, const B &rhs) { ... }

然后b a将调用第一个运算符,b将调用. b b将拨打第二个.

或者,您可以通过将其放在B类中来“取消隐藏”基类实现:

using A::operator+;

不过,最好不要这样做.大多数运算符作为自由函数更好地工作,因为这样就可以在两个操作数上实现自动转换. C永远不会在成员函数调用的LHS上执行转换.

顺便说一句,运算符几乎肯定应该按值返回,而不是通过引用返回,因为一旦函数返回,自动(堆栈)变量就不再存在了.因此调用者需要传递结果的副本,而不是对它的引用.出于这个原因,运算符和继承不是很好的组合,尽管只要调用者知道他们正在做什么,它就可以工作.

本文共计583个文字,预计阅读时间需要3分钟。

c派生类中如何实现重载父类的特定方法?

我遇到以下问题:假设有基类A的方法:A operator+(A a){...},我还有一个派生类B,它重载了这个方法:B operator+(B b){...}。问题是:如果我想要打电话给b+a(其中b是B类型,A类型是A的子类),我该怎么做?

我有以下问题:

假设基类A的方法:

A& operator+(A& a) {...}

我还有一个派生类B,它重载(或至少应该这样)这个方法:

A& operator+(B& b) {...}

问题是如果我想打电话给:
b a(其中b是B类型,A类型是A)我得到编译错误.
(错误C2679:二进制”:找不到带有’A’类型右手操作数的运算符(或者没有可接受的转换)).

不应该调用基类方法吗? (看起来它覆盖了方法..)
如果没有,为什么?有没有办法解决这个问题(不要告诉我用B&A重载B中的方法)

对不起,我不提供格式化文本的例子,但我不知道如何格式化它.

提前致谢!

PS Im使用Visual Studio 2010测试版.

不,它不会调用基类函数. B类有一个操作符,它没有采用正确的参数,故事结束.

您可以将运算符定义为自由函数,而不是任何类.也许是朋友,如果需要访问私人数据:

c派生类中如何实现重载父类的特定方法?

A operator+(const A &lhs, const A &rhs) { ... } B operator+(const B &lhs, const B &rhs) { ... }

然后b a将调用第一个运算符,b将调用. b b将拨打第二个.

或者,您可以通过将其放在B类中来“取消隐藏”基类实现:

using A::operator+;

不过,最好不要这样做.大多数运算符作为自由函数更好地工作,因为这样就可以在两个操作数上实现自动转换. C永远不会在成员函数调用的LHS上执行转换.

顺便说一句,运算符几乎肯定应该按值返回,而不是通过引用返回,因为一旦函数返回,自动(堆栈)变量就不再存在了.因此调用者需要传递结果的副本,而不是对它的引用.出于这个原因,运算符和继承不是很好的组合,尽管只要调用者知道他们正在做什么,它就可以工作.