Scroll to navigation

std::function::target(3) C++ Standard Libary std::function::target(3)

NAME

std::function::target - std::function::target

Synopsis


template< class T > (1) (since C++11)
T* target() noexcept;
template< class T > (2) (since C++11)
const T* target() const noexcept;


Returns a pointer to the stored callable function target.

Parameters


(none)

Return value


A pointer to the stored function if target_type() == typeid(T), otherwise a null
pointer.

Example

// Run this code


#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 function: ";
if (arg.target<std::plus<int>>())
std::cout << "it is plus\n";
if (arg.target<std::minus<int>>())
std::cout << "it is minus\n";


int (*const* ptr)(int, int) = arg.target<int(*)(int, int)>();
if (ptr && *ptr == f)
std::cout << "it is the function f\n";
if (ptr && *ptr == g)
std::cout << "it is the function 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));
}

Output:


test function: it is plus
test function: it is minus
test function: it is the function f
test function: it is the function g


Defect reports


The following behavior-changing defect reports were applied retroactively to
previously published C++ standards.


DR Applied to Behavior as published Correct behavior
LWG 2591 C++11 the behavior is undefined if T is behavior is defined (always
not Callable returns nullptr)

See also


target_type obtains the typeid of the stored target
(public member function)

2024.06.10 http://cppreference.com