Defined in header <any> | ||
---|---|---|
class any; | (since C++17) |
The class any
describes a type-safe container for single values of any copy constructible type.
any
stores an instance of any type that satisfies the constructor requirements or is empty, and this is referred to as the state of the class any
object. The stored instance is called the contained object. Two states are equivalent if they are either both empty or if both are not empty and if the contained objects are equivalent.any_cast
functions provide type-safe access to the contained object.Implementations are encouraged to avoid dynamic allocations for small objects, but such an optimization may only be applied to types for which std::is_nothrow_move_constructible
returns true
.
constructs an any object (public member function) |
|
assigns an any object (public member function) |
|
destroys an any object (public member function) |
|
Modifiers |
|
change the contained object, constructing the new object directly (public member function) |
|
destroys contained object (public member function) |
|
swaps two any objects (public member function) |
|
Observers |
|
checks if object holds a value (public member function) |
|
returns the typeid of the contained value (public member function) |
(C++17) | specializes the std::swap algorithm (function) |
(C++17) | type-safe access to the contained object (function template) |
(C++17) | creates an any object (function template) |
(C++17) | exception thrown by the value-returning forms of any_cast on a type mismatch (class) |
Feature-test macro | Value | Std | Comment |
---|---|---|---|
__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'; }
Possible output:
int: 1 double: 3.14 bool: true bad any_cast int: 2 no value 3
(C++11) | wraps callable object of any copy constructible type with specified function call signature (class template) |
(C++23) | wraps callable object of any type with specified function call signature (class template) |
(C++17) | a type-safe discriminated union (class template) |
(C++17) | a wrapper that may or may not hold an object (class template) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/utility/any