std::make_any
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <any>
|
||
template< class T, class... Args > std::any make_any( Args&&... args ); |
(1) | (начиная с C++17) |
template< class T, class U, class... Args > std::any make_any( std::initializer_list<U> il, Args&&... args ); |
(2) | (начиная с C++17) |
Создаёт объект any, содержащий объект типа T, передавая предоставленные аргументы конструктору T.
1) Эквивалент
return std::any(std::in_place_type<T>, std::forward<Args>(args)...);2) Эквивалент
return std::any(std::in_place_type<T>, il, std::forward<Args>(args)...);Пример
Запустить этот код
#include <any>
#include <complex>
#include <functional>
#include <iostream>
#include <string>
int main()
{
auto a0 = std::make_any<std::string>("Привет, std::any!\n");
auto a1 = std::make_any<std::complex<double>>(0.1, 2.3);
std::cout << std::any_cast<std::string&>(a0);
std::cout << std::any_cast<std::complex<double>&>(a1) << '\n';
using lambda = std::function<void(void)>;
// Помещает лямбду в std::any. Попытка #1 (неудачная).
std::any a2 = [] { std::cout << "Лямбда #1.\n"; };
std::cout << "a2.type() = \"" << a2.type().name() << "\"\n";
// any_cast приводит к <void(void)>, но фактический тип не
// std::function..., а ~ main::{lambda()#1}, и он уникален для
// каждой лямбды. Итак, это бросает...
try {
std::any_cast<lambda>(a2)();
}
catch (std::bad_any_cast const& ex) {
std::cout << ex.what() << '\n';
}
// Помещает лямбду в std::any. Попытка #2 (успешная).
auto a3 = std::make_any<lambda>([] { std::cout << "Лямбда #2.\n"; });
std::cout << "a3.type() = \"" << a3.type().name() << "\"\n";
std::any_cast<lambda>(a3)();
}
Возможный вывод:
Привет, std::any!
(0.1,2.3)
a2.type() = "Z4mainEUlvE_"
bad any_cast
a3.type() = "St8functionIFvvEE"
Лямбда #2.
Смотрите также
создаёт объект any (public функция-элемент) | |
(C++17) |
типобезопасный доступ к содержащемуся объекту (шаблон функции) |