c – 从派生类中删除虚函数
发布时间:2020-12-16 05:55:04 所属栏目:百科 来源:网络整理
导读:我有一个虚拟的基类函数,不应该在一个特定的派生类中使用.有没有办法“删除”呢?我当然可以给它一个空的定义,但我宁愿使用它尝试使用抛出一个编译时错误. C 11删除说明符似乎是我想要的,但是 class B{ virtual void f();};class D : public B{ virtual void
我有一个虚拟的基类函数,不应该在一个特定的派生类中使用.有没有办法“删除”呢?我当然可以给它一个空的定义,但我宁愿使用它尝试使用抛出一个编译时错误. C 11删除说明符似乎是我想要的,但是
class B { virtual void f(); }; class D : public B { virtual void f() = delete; //Error }; 不会编译;至少,gcc显然不会让我删除一个没有删除的基本版本的函数.有另一种获得相同功能的方法吗? 解决方法
标准不允许,但是您可以使用以下两种解决方法之一来获得类似的行为.
第一个是使用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!"); } }; 另一种解决办法是在使用该方法时抛出异常,但这只会在运行时抛出. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |