命名空间
变体
操作

std::any

来自 cppreference.cn
< cpp‎ | utility
 
 
 
 
定义于头文件 <any>
class any;
(自 C++17 起)

any 描述了用于任何可复制构造类型单值的类型安全容器。

1)any 的对象存储满足构造函数要求的任何类型的实例或为空,这被称为 any 类对象状态。存储的实例称为包含对象。如果两个状态都为空,或者都不为空且包含对象等效,则它们是等效的。
2) 非成员 any_cast 函数提供对包含对象的类型安全访问。

鼓励实现避免对小对象进行动态分配,但这种优化可能仅适用于 std::is_nothrow_move_constructible 返回 true 的类型。

内容

[编辑] 成员函数

构造一个 any 对象
(公共成员函数) [编辑]
赋值一个 any 对象
(公共成员函数) [编辑]
销毁一个 any 对象
(公共成员函数) [编辑]
修改器
更改包含的对象,直接构造新对象
(公共成员函数) [编辑]
销毁包含的对象
(公共成员函数) [编辑]
交换两个 any 对象
(公共成员函数) [编辑]
观察器
检查对象是否持有值
(公共成员函数) [编辑]
返回包含值的 typeid
(公共成员函数) [编辑]

[编辑] 非成员函数

特化 std::swap 算法
(函数) [编辑]
(C++17)
对包含对象的类型安全访问
(函数模板) [编辑]
(C++17)
创建一个 any 对象
(函数模板) [编辑]

[编辑] 辅助类

当类型不匹配时,由 any_cast 的值返回形式抛出的异常
(类) [编辑]

[编辑] 注释

特性测试 Std 特性
__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++17)
类型安全的判别联合
(类模板) [编辑]
(C++17)
可能持有或不持有对象的包装器
(类模板) [编辑]