我正在实现一个带有 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/