如何解决为什么我的编译器不允许将已删除的非抛出虚拟成员函数覆盖为已删除的抛出成员函数?
我读过 C++ 入门第 5 版。不会抛出 (virtual
) 的 noexcept
成员函数必须被重写为非抛出函数。例外情况是 virtual
成员函数被定义为“已删除”成员。
所以我试过了:
struct Foo{
virtual void func() const noexcept = delete;
};
struct Bar : Foo{
virtual void func() const noexcept(false) override = delete; // or let the compiler make it implicitly a throwing function
};
-
looser exception specification on overriding virtual function ‘virtual void Bar::func() const noexcept (false)’|
-
我搜索了 cppreference 并发现了相同的想法:
如果一个虚函数是非抛出的,则每个重写器的所有声明,包括定义,也必须是非抛出的,除非重写器被定义为已删除。这是来自 cppreference 的代码:
struct B {
virtual void f() noexcept;
virtual void g();
virtual void h() noexcept = delete;
};
struct D: B {
void f(); // ill-formed: D::f is potentially-throwing,B::f is non-throwing
void g() noexcept; // OK
void h() = delete; // OK
};
当我从 cppreference 编译程序时,我得到与我的示例相同的错误。 (除了不应编译的 f()
)。所以考虑我在 void f();
中注释掉 struct D
。编译器对 void h() = delete;
抱怨相同。
那么我的编译器有什么问题?谢谢!
注意:我已经在他们的网站上尝试了 cppreference 中的代码,并在 struct f()
中注释掉了 D
并且代码也没有编译?!那么这也是他网站上的错误吗?
clang 和 gcc 示例:https://www.godbolt.org/z/f7hzbG
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。