The std::function() in C++ is a function wrapper class which can store and call any function or a callable object. In this article, we will learn about std::function in C++ and how to use it in different cases.
What is std::function in C++?
std::function is a template class in C++ that is used to wrap a particular function or any other callable object such as a lambda, or function object. It is generally used to write generic code where we need to pass functions as arguments in another function (callbacks). It avoids the creation of extra overloads of the function that may take similar callback functions as arguments.
std::function is defined in the <functional> header file.
Declaration
To create a wrapper object, we first declare it using the following syntax:
std::function< rtype (atype...)> name();
where,
- name: Name of the wrapper.
- atype: Types of the arguments that function takes.
- rtype: Return type of the function you want to store.
Initialization
The above syntax only creates an empty instance of std::function. To wrap a particular function inside this wrapper object, we use assignment operator as shown:
std::function< ret_t (args_t)> name = f;
where f is the function to be wrapped.
We can also initialize it at the time of declaration:
std::function< ret_t (args_t)> name(f);
Example of std::function
C++
// C++ Program to illustrate the working
// std::function
#include <bits/stdc++.h>
using namespace std;
int f(int a, int b) {
return a + b;
}
int main() {
// std::function wrapping traditional
// function
function<int(int, int)> calc = f;
cout << "Sum: " << calc(8, 2) << endl;
// std::function wrapping a lambda
// expression
calc = [](int a, int b) { return a * b; };
cout << "Product: " << calc(8, 2);
return 0;
}
OutputSum: 10
Product: 16
Member Functions of std::function
std::function contains some member functions to provide some basic functionality. The following table lists some useful member functions of std::function class template:
Function | Description |
---|
swap() | Swaps the wrapped callable of two std::function objects. |
operator bool | Checks if the std::function contains a callable. |
operator () | Invoke the callable with the given arguments. |
target() | Returns a pointer to the stored callable. If there is no callable stored, returns nullptr. |
target_type() | Returns the typeid of the callable. If no callable is stored, it returns typeid(void) . |
Applications of std::functions in C++
Apart from the applications shown in the above examples, std::function can also be used for:
- Callbacks: Used for event-driven systems where functions are passed and called later when an event occurs.
- Function Wrapping and Higher-Order Functions: Allows passing functions as parameters and returning them.
- Stateful Callbacks: Enables callbacks with preserved states, making it easier to manage state without global variables.
- Replacing Function Pointers: Provides a safer and more flexible alternative to traditional function pointers, supporting multiple callable types.
More Examples of std::function
The following examples demonstrates the usage of std::function in C++ for different applications such as callbacks, state preserved callbacks, function composition.
Example 1: Passing std::function as Argument (Callback)
C++
// C++ program to pass the std::function
// as arguments
#include <bits/stdc++.h>
using namespace std;
// Functions for simple math operations
int add(int a, int b) {
return a + b;
}
int sub(int a, int b) {
return a - b;
}
int mul(int a, int b) {
return a * b;
}
int divs(int a, int b) {
return a / b;
}
// Using std::function as parameter
void func(int a, int b,
function<int(int, int)> calc) {
int res = calc(a, b);
cout << "Result: " << res << endl;
}
int main() {
// Calling all the arithmetic functions
func(8, 2, add);
func(8, 2, sub);
func(8, 2, mul);
func(8, 2, divs);
return 0;
}
OutputResult: 10
Result: 6
Result: 16
Result: 4
Example 2: Wrapping Member Functions of a Class
We can also wrap a member function of a class using std::function object but we have to add one extra argument as shown in the below program.
C++
// C++ program to demonstrate usage of
// unction with member functions
#include <bits/stdc++.h>
using namespace std;
class C {
public:
int f(int a, int b) {
return a * b;
}
};
int main() {
C c;
// Wrapping member function of C
function<int(C&, int, int)> calc = &C::f;
// Call the member function using function
if (calc)
cout << "Product: " << calc(c, 4, 5);
else
cout << "No Callable Assigned";
return 0;
}
Example 3: Composing Two Functions into One
C++
// C++ program to demonstrate usage of
// std::function for function composition
#include <bits/stdc++.h>
using namespace std;
// Composed function
function<int(int)> cf(function<int(int)> f1,
function<int(int)> f2) {
// Returning a lambda expression that
// in turn returns a function
return [f1, f2](int x) {
// Apply f1 first, then f2
return f2(f1(x));
};
}
int main() {
auto add = [](int x) { return x + 2; };
auto mul = [](int x) { return x * 3; };
function<int(int)> calc = cf(add, mul);
cout << calc(4);
return 0;
}
Explanation: In this example, we composted two lambda functions add() and mul() into one function cf() which takes two function wrappers and returns another function wrapper. Then we created a wrapper for this using this composed function and use it to perform the addition and multiplication operator at one call.
Similar Reads
strol() function in C++
The strtol() function in C++ interprets the contents of a string as an integral number of the specified base and return its value as a long int.This function also sets an end pointer that points to the first character after the last valid numeric character of the string, if there is no such characte
3 min read
strtod() function in C/C++
The strtod() is a builtin function in C and C++ STL which interprets the contents of the string as a floating point number and return its value as a double. It sets a pointer to point to the first character after the last valid character of the string, only if there is any, otherwise it sets the poi
4 min read
strcat() Function in C++
The strcat() function in C++ is a predefined function in the <cstring> header file that is used to concatenate two strings, by appending a copy of the source string to the end of the destination string. This function works by adding all the characters till the null character of the source stri
2 min read
Functions in C++
A function is a building block of C++ programs that contains a set of statements which are executed when the functions is called. It can take some input data, performs the given task, and return some result. A function can be called from anywhere in the program and any number of times increasing the
9 min read
String Functions In C++
A string is referred to as an array of characters. In C++, a stream/sequence of characters is stored in a char array. C++ includes the std::string class that is used to represent strings. It is one of the most fundamental datatypes in C++ and it comes with a huge set of inbuilt functions. In this ar
9 min read
log() Function in C++
The std::log() in C++ is a built-in function that is used to calculate the natural logarithm (base e) of a given number. The number can be of any data type i.e. int, double, float, long long. It is defined inside the <cmath> header file. In this article we will learn about how to use std::log(
2 min read
Function Pointer in C
In C, a function pointer is a type of pointer that stores the address of a function, allowing functions to be passed as arguments and invoked dynamically. It is useful in techniques such as callback functions, event-driven programs, and polymorphism (a concept where a function or operator behaves di
6 min read
Function Pointer in C++
Prerequisites: Pointers in C++Function in C++ Pointers are symbolic representations of addresses. They enable programs to simulate call-by-reference as well as to create and manipulate dynamic data structures. Iterating over elements in arrays or other data structures is one of the main use of point
4 min read
Virtual Function in C++
A virtual function (also known as virtual methods) is a member function that is declared within a base class and is re-defined (overridden) by a derived class. When you refer to a derived class object using a pointer or a reference to the base class, you can call a virtual function for that object a
6 min read
mktime() function in C++ STL
The mktime() is an inbuilt C++ function which converts the local calendar time to the time since epoch and returns the value as an object of type time_t. Syntax : time_t mktime( struct tm *time_ptr ) Parameters: The function accepts a mandatory parameter pointer time_ptr that points to a tm object s
2 min read