c++ - 如何在 noexcept 运算符中引用移动构造函数

标签 c++ exception stl

我正在实现一个带有 IsNothrowMoveConstructible 属性的 TypeInfo 类。如果类型 T 的移动构造函数标有 noexcept,我想将此参数设置为 true。通过 noexcept(noexcept(T())) 引用默认构造函数似乎可行,但是我还没有弄清楚如何引用移动构造函数。我想解决方案将是这样的:

template <typename T> 
struct TypeInfo 
{
    enum
    {
        ...
        IsNothrowMoveConstructible = noexcept(noexcept(T(T&&))),
        ...
    };
};

我知道,我可以使用 std::is_nothrow_move_constructible,但我的目标是找出在这种情况下如何使用 noexcept() 运算符。

最佳答案

运营商noexcept()需要一个真实的表达。不幸的是 T(T&&) 不是一个有效的表达式。

因此您需要实例化 T 并使用 std::move() 来确保它使用移动构造函数(如果有的话)。这是一个概念证明:

template <typename T> 
struct TypeInfo 
{
    bool test() 
    {
        T t;
        bool IsNothrowMoveConstructible = noexcept(T(std::move(t)));
        return IsNothrowMoveConstructible;
    };
};

问题是这变得更容易出错。如果 T 没有默认构造函数,它将无法编译。如果移动构造函数被隐式或显式删除,则相同。

但是如果您可以忍受这些缺陷,因为该值是在编译时确定的,因此是常量,您可以使用 T 成员并在枚举中定义一个常量:

struct TypeInfo 
{
    T t; 
    enum {
        IsNothrowMoveConstructible = noexcept(T(std::move(t)))
    }; 
};

这里是online demo .

关于c++ - 如何在 noexcept 运算符中引用移动构造函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52585155/

相关文章:

c++ - 如何将临时 C 数组传递到 constexpr 容器中

c++ - 将结构复制到另一个相同类型的结构时出错

android - Android:forceclose应用出现故障后

c++ - 使用交换函数交换 vector 和数组中两行的复杂性

c++ - 合并两个 std::sets

c++ - 空 vector 的开销成本是多少?

c++ - 标准如何支持在基类 S 中调用纯虚函数?

c++ - 将注册表项 HANDLE 转换为 HKEY

c# - 调用通用反射方法时对象引用未设置为对象的实例

exception - 如何捕获 monotouch/ios 中的所有崩溃异常?