Namespaces
Variants

std::function<R(Args...)>:: target_type

From cppreference.net
Utilities library
Function objects
Function invocation
(C++17) (C++23)
Identity function object
(C++20)
Old binders and adaptors
( until C++17* )
( until C++17* )
( until C++17* )
( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
( until C++20* )
( until C++20* )
( until C++17* ) ( until C++17* )
( until C++17* ) ( until C++17* )

( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
( until C++20* )
( until C++20* )
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 могут использоваться deduction guides (CTAD)
    std::cout << std::function{g}.target_type().name() << '\n';
}

Возможный вывод:

PFiiE
Z4mainEUliE_
PFvdE

Смотрите также

получает указатель на сохранённый целевой объект
(публичная функция-член)
содержит информацию о некотором типе, класс, возвращаемый оператором typeid
(класс)
typeid запрашивает информацию о типе, возвращая объект std::type_info , представляющий тип
(оператор)