我有一个虚拟的基类函数,不应该在一个特定的派生类中使用.有没有办法“删除”呢?我当然可以给它一个空的定义,但我宁愿使用它尝试使用抛出一个编译时错误. C 11删除说明符似乎是我想要的,但是
class B { virtual void f(); }; class D : public B { virtual void f() = delete; //Error };
解决方法
标准不允许,但是您可以使用以下两种解决方法之一来获得类似的行为.
第一个是使用use来将该方法的可见性更改为private,从而防止其他人使用它.该解决方案的问题是,在超类的指针上调用该方法不会导致编译错误.
class B { public: virtual void f(); }; class D : public B { private: using B::f; };
在调用Ds方法时,我发现迄今为止发现的最佳解决方案是使用一个带有从false_type继承的通用结构体的static_assert.只要没有人调用该方法,struct保持不变,static_assert将不会失败.
如果调用该方法,则定义该结构,其值为false,因此static_assert将失败.
如果方法未被调用,但是您尝试在超级类的指针上调用该方法,那么Ds方法未被定义,并且您会收到一个未定义的引用编译错误.
template <typename T> struct fail : std::false_type { }; class B { public: virtual void f() { } }; class D : public B { public: template<typename T = bool> void f() { static_assert (fail<T>::value,"Do not use!"); } };