有没有办法在不重新实现的情况下从子类中标记父级的虚拟函数 final。
Is there a way to mark a parent's virtual function final from a child class without reimplementing it
如果我有代码:
struct Parent
{
virtual void fn();
};
struct Child : public Parent
{
virtual void fn() override final
{
Parent::fn();
}
};
有没有办法让Parent::fn
仅在通过Child
访问时才final
而不重新实现fn
,以便其他一些class
可以在从Parent
派生时覆盖fn
,但在从Child
派生时不能覆盖?
喜欢:
struct Child : public Parent
{
virtual void fn() override final = Parent::fn;
};
还是其他语法?
不,如果不重新实现它,你就无法做到这一点。所以只需重新实现它:
struct Child : public Parent
{
virtual void fn() override final { Parent::fn(); }
};
注意:说virtual ... override final
是完全多余的,final
是非虚函数的错误,所以你应该说:
void fn() final { Parent::fn(); }
请参阅 http://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines#Rh-override
相关文章:
- 继承期间显示未知行为的子类
- 通过指向指针数组的指针访问子类的属性
- 从父类方法返回子类对象
- c++, 在子类中,如何在没有对象的情况下访问父类的方法?
- 将父类对象强制转换为子类的问题
- 避免在C++中重复子类定义
- 将QOpenGLWidget子类转换为使用Metal而不是OpenGL的子类是否可行?
- 如何初始化矢量的模板化子类
- C++ 继承:将子类传递给需要基类的函数并获取子类行为
- 有没有办法按值将纯抽象类的所有子类传递给 C++ 中的函数?
- 使用子类覆盖基类中定义的函数
- 子类地址等于虚拟基类地址?
- 将子类方法声明为基类的友元
- C++子类共享变量?
- 如何检查模板专用化是否是基本模板的子类?
- 仅让特定类'Fabric'构造类'Foo'及其所有子类的实例
- 使用模板参数重载C++方法:如何使其适用于模板的子类?
- 基类中的默认析构函数禁用子类中的移动构造函数(如果有成员)
- 如何在C++子类中访问父类的私有变量
- 有没有办法在不重新实现的情况下从子类中标记父级的虚拟函数 final。