给定以下代码:
template<typename T>
constexpr remove_reference_t<decltype(T{}.x, bool{})> has_x() {return true;}
template<typename T, class... U>
constexpr bool has_x(U...) {return false;}
class A { public: int x; };
int main()
{
vector<int> vec;
A my_a{};
std::cout << has_x<decltype(my_a)>() << endl << has_x<decltype(vec)>() << endl;
if constexpr(has_x<decltype(vec)>())
{
cout << vec.x << endl;
}
else
{
cout << size(vec) << endl;
}
}
只有当我注释掉cout << vec.x << endl
. 这显然不会编译,但我的理解if constexpr
是:
如果值为
true
,则丢弃 statement-false(如果存在),否则丢弃 statement-true
因此,我认为应该丢弃“statement-true”,但似乎并非如此。如果我在“statement-true”中放置一个在任何一种情况下都有效的陈述,它就会起作用。但是我得到一个可能无效的声明:
错误:
class std::vector<int>
没有名为的成员x
我在这里做错了吗?