为什么 constexpr 变量的 decltype 失败?
#include <cstdint>
#include <type_traits>
constexpr uint16_t foo(){ return 0;}
constexpr auto cv = foo();
auto v = foo();
static_assert( std::is_same< uint16_t, decltype(cv)>::value, "!"); // failed
static_assert( std::is_same< uint16_t, decltype(v) >::value, "!"); // success
decltype(entity)指定声明的类型entity
由该表达式指定。
因为constexpr, (A constexpr
对象声明中使用的说明符意味着const
), your cv
变量的类型const uint16_t
.
你懂的const uint16_t
不同于uint16_t
然后你的行:
static_assert( std::is_same< uint16_t, decltype(cv)>::value, "!");
正如预期的那样失败。
The line
constexpr uint16_t foo(){ return 0;}
指定该函数foo
可以在编译时求值,但该函数仍然返回uint16_t
。这就是为什么上线
auto v = foo();
v
属于类型uint16_t
然后线
static_assert( std::is_same< uint16_t, decltype(v) >::value, "!");
也按预期工作。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)