加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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!");
    }
};

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读