std::is_literal_type
来自cppreference.com
在标头 <type_traits> 定义
|
||
template< class T > struct is_literal_type; |
(C++11 起) (C++17 中弃用) (C++20 中移除) |
|
(由于对泛型编程而言十分鸡肋,这项类型特性(type trait)已经弃用[1]并移除[2] 。)
若 T
满足所有字面类型 (LiteralType) 的要求,则提供等于 true 的成员常量 value
。对于任何其他类型, value
为 false 。
若 std::remove_all_extents_t<T> 为不完整类型且非(可有 cv 限定的) void 则行为未定义。
添加 is_literal_type
或 is_literal_type_v
(C++17 起) 的特化的程序行为未定义。
模板形参
T | - | 要检查的类型 |
辅助变量模板
template< class T > inline constexpr bool is_literal_type_v = is_literal_type<T>::value; |
(C++17 起) (弃用) (C++20 中移除) |
|
继承自 std::integral_constant
成员常量
value [静态] |
若 T 为字面类型则为 true ,否则为 false (公开静态成员常量) |
成员函数
operator bool |
转换对象为 bool ,返回 value (公开成员函数) |
operator() (C++14) |
返回 value (公开成员函数) |
成员类型
类型 | 定义 |
value_type
|
bool
|
type
|
std::integral_constant<bool, value> |
注意
唯有字面类型能作为 constexpr 函数的参数或返回类型。只有字面类能拥有 constexpr 成员函数。
示例
运行此代码
#include <iostream> #include <type_traits> struct A { int m; }; struct B { virtual ~B(); }; int main() { std::cout << std::boolalpha; std::cout << std::is_literal_type<A>::value << '\n'; std::cout << std::is_literal_type<B>::value << '\n'; }
输出:
true false
外部链接
- ↑ Alisdair Meredith. "Deprecate the is_literal Trait". Deprecating Vestigial Library Parts in C++17. "The is_literal type trait offers negligible value to generic code, as what is really needed is the ability to know that a specific construction would produce constant initialization."
- ↑ Alisdair Meredith, Stephan T. Lavavej, Tomasz Kamiński. "Deprecated type traits". Reviewing Deprecated Facilities of C++17 for C++20. "Strong recommendation: Remove the traits that can live on as zombies. [...] Toronto Review: Accept strong recommendation, strike from C++20."