◐ Shell
clean mode source ↗

std::function<R(Args...)>::target — cppreference.com

Материал из cppreference.com

<tbody> </tbody>

template< class T > T* target() noexcept;

(1) (начиная с C++11)

template< class T > const T* target() const noexcept;

(2) (начиная с C++11)

Возвращает указатель на сохранённую цель вызываемой функции.

Параметры

(нет)

Возвращаемое значение

Указатель на хранимую функцию, если target_type() == typeid(T), иначе нулевой указатель.

Пример

#include <functional>
#include <iostream>

int f(int, int) { return 1; }
int g(int, int) { return 2; }
void test(std::function<int(int, int)> const& arg)
{
    std::cout << "функция test: ";
    if (arg.target<std::plus<int>>())
        std::cout << "это plus\n";
    if (arg.target<std::minus<int>>())
        std::cout << "это minus\n";

    int (*const* ptr)(int, int) = arg.target<int(*)(int, int)>();
    if (ptr && *ptr == f)
        std::cout << "это функция f\n";
    if (ptr && *ptr == g)
        std::cout << "это функция g\n";
}

int main()
{
    test(std::function<int(int, int)>(std::plus<int>()));
    test(std::function<int(int, int)>(std::minus<int>()));
    test(std::function<int(int, int)>(f));
    test(std::function<int(int, int)>(g));
}

Вывод:

функция test: это plus
функция test: это minus
функция test: это функция f
функция test: это функция g

Отчёты о дефектах

Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:

Номер Применён Поведение в стандарте Корректное поведение
LWG 2591 C++11 поведение не определено, если T не Callable поведение определено (всегда возвращает nullptr)

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