std::function<R(Args...)>::target_type
Материал из cppreference.com
< cpp | utility | functional | function
const std::type_info& target_type() const noexcept; |
(начиная с C++11) | |
Возвращает тип сохранённой функции.
Содержание |
[править] Параметры
(нет)
[править] Возвращаемое значение
typeid(T), если хранимая функция имеет тип T
, иначе typeid(void)
[править] Пример
Запустить этот код
#include <functional> #include <iostream> int f(int a) { return -a; } void g(double) {} int main() { // fn1 и fn2 имеют одинаковый тип, но их цели нет std::function<int(int)> fn1(f), fn2([](int a) {return -a;}); std::cout << fn1.target_type().name() << '\n' << fn2.target_type().name() << '\n'; // начиная с C++17 могут помочь принципы вывода (CTAD) std::cout << std::function{g}.target_type().name() << '\n'; }
Возможный вывод:
PFiiE Z4mainEUliE_ PFvdE
[править] Смотрите также
получает указатель на сохранённую цель (public функция-элемент) | |
typeid | Запрашивает информацию о типе, возвращая объект std::type_info , представляющий тип.
|
содержит некоторую информацию о типе, сгенерированную реализацией. Это класс, возвращаемый оператором typeid. (класс) |