std::function<R(Args...)>::target
Материал из 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)
|
Смотрите также
получает typeid сохранённой цели (public функция-элемент) |