class Base {
public:
void foo() const {
std::cout << "foo const" << std::endl;
}
};
class Derived : public Base {
public:
void foo() {
std::cout << "foo"<< std::endl;
}
}
我想确保 foo() const 为 Base 正确隐藏。是的,这是个坏主意,也许我应该将 Base::foo() const 设为纯虚拟,以要求 Dervied::foo() 正确覆盖——但假设我无法将 Base::foo() 设为纯 const虚拟的。有没有更好的方法来确保 Base::foo() const 正确隐藏在 Derived 中?
编辑:我想确保在 Derived 中我已经正确地隐藏了基础实现。
最佳答案
只需在派生类中定义一个成员函数 foo,您就隐藏了基类中的所有 foo 函数。
您需要稍微细化一下问题 - 您是否担心派生类中的 foo 不能正确替代基类中的 foo?我很难确定您真正要求的是什么。
编辑:根据您的编辑和其他评论,我认为您误解了 C++ 中隐藏的工作原理。在这种情况下,一个函数是 const 而另一个不是 const 并不重要——一旦 C++ 在派生类中找到一个函数 foo,它就会停止在其他任何地方寻找!这对人们来说通常是一个巨大的陷阱。请考虑以下事项:
class Base
{
void foo(double d)
{
cout << d;
}
};
class Derived : public Base
{
void foo(int i)
{
cout << i;
}
};
Derived obj;
obj.foo(123.456);
你认为输出是什么?是123!您可能会收到一个编译器警告,告诉您 double 值将被截断。尽管采用 double 的函数签名显然是更好的匹配,但从未考虑过 - 它已被隐藏。
关于c++ - 如何确保在 C++ 中覆盖(隐藏)派生类中的方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/889324/