std::function<R(Args...)>::target — cppreference.com
Материал из cppreference.com
<tbody> </tbody>
|
|
(1) | (начиная с C++11) |
|
|
(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)
|