std::is_implicit_lifetime
来自cppreference.com
<tbody>
</tbody>
| 在标头 <type_traits> 定义
|
||
template< class T > struct is_implicit_lifetime; |
(C++23 起) | |
std::is_implicit_lifetime 是一元类型特征 (UnaryTypeTrait) 。
如果 T 是隐式生存期类型,那么提供的成员常量 value 等于 true。对于其它任何类型,value 等于 false。
如果 T 是除了数组类型和(可能有 cv 限定的)void 以外的不完整类型,那么行为未定义。
如果程序添加了 std::is_implicit_lifetime 或 std::is_implicit_lifetime_v 的特化,那么行为未定义。
模板形参
| T | - | 要检查的类型 |
辅助变量模板
<tbody> </tbody> template< class T > constexpr bool is_implicit_lifetime_v = is_implicit_lifetime<T>::value; |
(C++23 起) | |
继承自 std::integral_constant
成员常量
value [静态] |
如果 T 是隐式生存期类型那么是 true,否则是 false (公开静态成员常量) |
成员函数
operator bool |
将对象转换到 bool,返回 value (公开成员函数) |
operator() (C++14) |
返回 value (公开成员函数) |
成员类型
| 类型 | 定义 |
value_type
|
bool
|
type
|
std::integral_constant<bool, value>
|
注解
| 功能特性测试宏 | 值 | 标准 | 功能特性 |
|---|---|---|---|
__cpp_lib_is_implicit_lifetime |
202302L |
(C++23) | std::is_implicit_lifetime
|
示例
运行此代码
// 以下类型统称为隐式生存期类型:
// * 标量类型:
// * 算术类型
// * 枚举类型
// * 指针类型
// * 成员指针类型
// * std::nullptr_t
// * 隐式生存期类类型
// * 其为聚合体且其析构函数并非由用户提供
// * 其具有至少一个平凡的合格构造函数和一个平凡的未弃置析构函数
// * 数组类型
// * 这些类型的 cv 限定版本
#include <type_traits>
static_assert(std::is_implicit_lifetime_v<int>); // 算术类型是标量类型
static_assert(std::is_implicit_lifetime_v<const int>); // cv 限定的标量类型
enum E { e };
static_assert(std::is_implicit_lifetime_v<E>); // 枚举类型是标量类型
static_assert(std::is_implicit_lifetime_v<int*>); // 指针类型是标量类型
static_assert(std::is_implicit_lifetime_v<std::nullptr_t>); // 标量类型
struct S { int x, y; };
// S 是隐式生存期类:没有用户提供析构函数的聚合体
static_assert(std::is_implicit_lifetime_v<S>);
static_assert(std::is_implicit_lifetime_v<int S::*>); // 成员指针
struct X { ~X() = delete; };
// 由于弃置的析构函数,X 不是隐式生存期类
static_assert(!std::is_implicit_lifetime_v<X>);
static_assert(std::is_implicit_lifetime_v<int[8]>); // 数组类型
static_assert(std::is_implicit_lifetime_v<volatile int[8]>); // cv 限定的数组类型
int main() {}
参阅
(C++11) |
检查类型是否为标量类型 (类模板) |
(C++11) |
检查类型是否为数组类型 (类模板) |
(C++17) |
检查类型是否为聚合类型 (类模板) |
| 在给定的存储上创建对象并复用对象表示 (函数模板) |