std::any
来自 cppreference.cn
定义于头文件 <any> |
||
class any; |
(C++17 起) | |
any
类描述了一个类型安全的容器,用于存储任意可复制构造类型的单个值。
1)
any
类的对象存储满足构造函数要求的任何类型实例,或者为空,这被称为 any
对象的*状态*。存储的实例被称为所包含的对象。如果两个状态都为空,或者都非空且所包含的对象等价,则这两个状态等价。2) 非成员函数
any_cast
提供对所包含对象的类型安全访问。鼓励实现避免对小型对象进行动态分配,但这种优化只能应用于满足 std::is_nothrow_move_constructible 返回 true
的类型。
目录 |
[编辑] 成员函数
构造一个 any 对象(公共成员函数) | |
赋值一个 any 对象(公共成员函数) | |
销毁一个 any 对象(公共成员函数) | |
修改器 | |
更改所包含的对象,直接构造新对象 (公共成员函数) | |
销毁所包含的对象 (公共成员函数) | |
交换两个 any 对象(公共成员函数) | |
观察器 | |
检查对象是否包含值 (公共成员函数) | |
返回所包含值的 typeid (公共成员函数) |
[编辑] 非成员函数
(C++17) |
特化 std::swap 算法 (函数) |
(C++17) |
类型安全地访问所包含的对象 (函数模板) |
(C++17) |
创建一个 any 对象(函数模板) |
[编辑] 辅助类
(C++17) |
当 any_cast 的值返回形式发生类型不匹配时抛出的异常(类) |
[编辑] 注解
特性测试宏 | 值 | 标准 | 特性 |
---|---|---|---|
__cpp_lib_any |
201606L |
(C++17) | std::any
|
[编辑] 示例
运行此代码
#include <any> #include <iostream> int main() { std::cout << std::boolalpha; // any type std::any a = 1; std::cout << a.type().name() << ": " << std::any_cast<int>(a) << '\n'; a = 3.14; std::cout << a.type().name() << ": " << std::any_cast<double>(a) << '\n'; a = true; std::cout << a.type().name() << ": " << std::any_cast<bool>(a) << '\n'; // bad cast try { a = 1; std::cout << std::any_cast<float>(a) << '\n'; } catch (const std::bad_any_cast& e) { std::cout << e.what() << '\n'; } // has value a = 2; if (a.has_value()) std::cout << a.type().name() << ": " << std::any_cast<int>(a) << '\n'; // reset a.reset(); if (!a.has_value()) std::cout << "no value\n"; // pointer to contained data a = 3; int* i = std::any_cast<int>(&a); std::cout << *i << '\n'; }
可能的输出
int: 1 double: 3.14 bool: true bad any_cast int: 2 no value 3
[编辑] 参阅
(C++11) |
任何可复制构造的可调用对象的包装器 (类模板) |
(C++23) |
任何支持给定调用签名中限定符的可调用对象的仅移动包装器 (类模板) |
(C++17) |
一种类型安全的带判别联合体 (类模板) |
(C++17) |
可能包含或不包含对象的包装器 (类模板) |