以下内容无法编译(Apple LLVM 版本 4.2 (clang-425.0.28)):
class A {
public:
virtual void foo() {};
virtual void foo( int i ) {};
};
class B : public A {
public:
virtual void foo( int i ) override { foo(); }
};
对于 B::foo(int) 内的 foo() 调用,编译器错误为“参数太少”。编译器显然认为我想递归调用 B::foo(int) 并且没有识别出我想调用 A::foo(void)。
如果我用 A::foo() 替换对 foo() 的调用,错误就会消失。
但是:
1) 为什么会发生这种情况?在这种情况下,显然只需解析为 A::foo() (或类层次结构中的重写函数)。
2)更重要的是,如果我也想对 foo(void) 使用多态后期绑定(bind),指定 A::foo() 不是我想要的,B::foo() 当然会产生编译器错误,如下所示好吧。
提前感谢您的启发!
最佳答案
派生类中的名称隐藏了基类中的相同名称。换句话说,当在 B
上下文中解析 foo
时,名称查找会找到 B::foo
并在那里停止。 A::foo
从未被发现。
在 B
的定义中添加 using A::foo;
。
关于c++ - C++ 中继承的重载规则,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18939161/