std::experimental::any_cast
From cppreference.com
< cpp | experimental | any
template<class ValueType> ValueType any_cast(const any& operand); |
(1) | (library fundamentals TS) |
template<class ValueType> ValueType any_cast(any& operand); |
(2) | (library fundamentals TS) |
template<class ValueType> ValueType any_cast(any&& operand); |
(3) | (library fundamentals TS) |
template<class ValueType> const ValueType* any_cast(const any* operand) noexcept; |
(4) | (library fundamentals TS) |
template<class ValueType> ValueType* any_cast(any* operand) noexcept; |
(5) | (library fundamentals TS) |
Performs type-safe access to the contained object.
For (1-3), the program is ill-formed if ValueType
is not a reference and std::is_copy_constructible<ValueType>::value is false.
Parameters
operand | - | target any object
|
Return value
1) Returns *any_cast<std::add_const_t<std::remove_reference_t<ValueType>>>(&operand).
2,3) Returns *any_cast<std::remove_reference_t<ValueType>>(&operand).
4,5) If operand is not a null pointer, and the
typeid
of the requested ValueType
matches that of the contents of operand, a pointer to the value contained by operand, otherwise a null pointer.Exceptions
1-3) Throws
bad_any_cast
if the typeid
of the requested ValueType
does not match that of the contents of operand.