首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >没有,除了可变is_nothrow_constructible_v

没有,除了可变is_nothrow_constructible_v
EN

Stack Overflow用户
提问于 2019-04-11 01:04:27
回答 1查看 125关注 0票数 2

他们中的哪一个是正确的,为什么?

我认为它是第一个,因为Ts已经有了与该类型相关联的&&const &,但我希望确定,noexcept的这种特殊情况的例子真的不是很多。

代码语言:javascript
复制
template <typename T>
struct Test {
    T test;

    // A
    template <typename... Ts>
    Test(Ts &&... ts) noexcept(std::is_nothrow_constructible_v<T, Ts...>)
        : test(std::forward<Ts>(ts)...) {
    }

    // B
    template <typename... Ts>
    Test(Ts &&... ts) noexcept(std::is_nothrow_constructible_v<T, Ts &&...>)
        : test(std::forward<Ts>(ts)...) {
    }
};
EN

回答 1

Stack Overflow用户

发布于 2019-04-11 01:22:22

我更喜欢选项C。您可以在noexcept说明符中使用noexcept operator,并让它为您计算调用的值。我发现这更容易读懂,因为你使用了你想要为异常说明符做的表达式。在您的情况下,这将看起来像

代码语言:javascript
复制
template <typename T>
struct Test {
    T test;

    // C
    template <typename... Ts>
    Test(Ts &&... ts) noexcept(noexcept(T(std::forward<Ts>(ts)...)))
        : test(std::forward<Ts>(ts)...) {
    }
};

现在代码显示,如果T(std::forward<Ts>(ts)...)为noexcept,则Test(Ts &&... ts)为noexcept。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55617890

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档