std::function<R(Args...)>::target_type
Материал из cppreference.com
<tbody>
</tbody>
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. (класс) |