科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道基础软件Bjarne:为何重载在继承类中不工作?

Bjarne:为何重载在继承类中不工作?

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

在C++中,没有跨越区域的重载——对于这条规则,继承类也不例外。

作者:Molly编译 来源:天极网 2007年10月27日

关键字: Bjarne 重载 Linux

  • 评论
  • 分享微博
  • 分享邮件
这个问题(非常常见)往往出现于这样的例子中:

#include<iostream>
using namespace std;

class B {
 public:
  int f(int i) { cout << "f(int): "; return i+1; }
  // ...
};

class D : public B {
 public:
  double f(double d) { cout << "f(double): "; return d+1.3; }
  // ...
};

int main()
{
 D* pd = new D;
 cout << pd->f(2) << ’\n’;
 cout << pd->f(2.3) << ’\n’;
}

  它输出的结果是:

f(double): 3.3
f(double): 3.6

  而不是象有些人猜想的那样:

f(int): 3
f(double): 3.6

  换句话说,在B和D之间并没有发生重载的解析。编译器在D的区域内寻找,找到了一个函数double f(double),并执行了它。它永远不会涉及(被封装的)B的区域。在C++中,没有跨越区域的重载——对于这条规则,继承类也不例外。

  但是,如果我需要在基类和继承类之间建立一组重载的f()函数呢?很简单,使用using声明:

class D : public B {
 public:
  using B::f; // make every f from B available
  double f(double d) { cout << "f(double): "; return d+1.3; }
  // ...
};

  进行这个修改之后,输出结果将是:

f(int): 3
f(double): 3.6

  这样,在B的f()和D的f()之间,重载确实实现了,并且选择了一个最合适的f()进行调用。

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章