微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c – 从派生类中删除虚函数

我有一个虚拟的基类函数,不应该在一个特定的派生类中使用.有没有办法“删除”呢?我当然可以给它一个空的定义,但我宁愿使用它尝试使用抛出一个编译时错误. 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!");
    }
};

另一种解决办法是在使用该方法时抛出异常,但这只会在运行时抛出.

原文地址:https://www.jb51.cc/c/113396.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐