非虚拟接口习惯用法描述了虚拟方法如何成为非公共定制点,而公共方法是非虚拟的,以允许基类始终控制定制点的调用方式。
这是一个优雅的习惯用法,我喜欢使用它,但是如果派生类本身就是一个基类,它是如何工作的
非虚拟接口习惯用法描述了虚拟方法如何成为非公共定制点,而公共方法是非虚拟的,以允许基类始终控制定制点的调用方式。
这是一个优雅的习惯用法,我喜欢使用它,但是如果派生类本身就是一个基类,它是如何工作的
它可以工作,因为派生类可以覆盖基类的私有虚函数,即使基类函数覆盖了它的基类函数。
这是完全合法的:
class Parent
{
public:
int foo() {return bar();} // the non-virtual public interface
private
virtual int bar();
};
class Child : public Parent
{
private:
virtual int bar(); // overrides Parent::bar()
};
class Grandchild : public Child
{
private:
virtual int bar(); // overrides Child::bar();
};
派生类可以自己决定:
您可以通过实现虚函数来完全覆盖该方法。您可以通过在派生类方法中的某个位置调用“中间”类函数来扩充该方法。
如果这不是您想要的,您需要在“中间”类中明确设置它。不过我不会。如果你发现自己想要这个,这可能意味着你没有给基类足够的定制点。