我有一个虚拟的基类函数,不应该在一个特定的派生类中使用.有没有办法“删除”呢?我当然可以给它一个空的定义,但我宁愿使用它尝试使用抛出一个编译时错误. 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!"); } };
原文地址:https://www.jb51.cc/c/113396.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。