std::function<R(Args...)>::function
function() noexcept; |
(1) | (since C++11) |
function( std::nullptr_t ) noexcept; |
(2) | (since C++11) |
function( const function& other ); |
(3) | (since C++11) |
(4) | ||
function( function&& other ); |
(since C++11) (until C++20) |
|
function( function&& other ) noexcept; |
(since C++20) | |
template< class F > function( F&& f ); |
(5) | (since C++11) |
template< class Alloc > function( std::allocator_arg_t, const Alloc& alloc ) noexcept; |
(6) | (since C++11) (removed in C++17) |
template< class Alloc > function( std::allocator_arg_t, const Alloc& alloc, |
(7) | (since C++11) (removed in C++17) |
template< class Alloc > function( std::allocator_arg_t, const Alloc& alloc, |
(8) | (since C++11) (removed in C++17) |
template< class Alloc > function( std::allocator_arg_t, const Alloc& alloc, |
(9) | (since C++11) (removed in C++17) |
template< class F, class Alloc > function( std::allocator_arg_t, const Alloc& alloc, F f ); |
(10) | (since C++11) (removed in C++17) |
Constructs a std::function
from a variety of sources.
std::function
specialization, *this will be empty right after the call.
|
(since C++23) |
- An lvalue of type std::decay<F>::type is callable for argument types
Args...
and return typeR
.
If std::is_copy_constructible_v<std::decay_t<F>> or std::is_constructible_v<std::decay_t<F>, F> is false, the program is ill-formed. |
(since C++23) |
F
is not CopyConstructible, the behavior is undefined.std::function
might use.When the target is a function pointer or a std::reference_wrapper, small object optimization is guaranteed, that is, these targets are always directly stored inside the std::function object, no dynamic allocation takes place. Other large objects may be constructed in dynamic allocated storage and accessed by the std::function object through a pointer.
Contents |
[edit] Parameters
other | - | the function object used to initialize *this |
f | - | a callable object used to initialize *this |
alloc | - | an Allocator used for internal memory allocation |
Type requirements | ||
-Alloc must meet the requirements of Allocator.
|
[edit] Exceptions
4) Does not throw if other's target is a function pointer or a std::reference_wrapper, otherwise may throw std::bad_alloc or any exception thrown by the constructor used to copy or move the stored callable object.
|
(until C++20) |
[edit] Notes
std::function
's allocator support was poorly specified and inconsistently implemented. Some implementations do not provide overloads (6-10) at all, some provide the overloads but ignore the supplied allocator argument, and some provide the overloads and use the supplied allocator for construction but not when the std::function
is reassigned. As a result, allocator support was removed in C++17.
[edit] Example
This section is incomplete Reason: no example |
[edit] 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 2132 | C++11 | overloads (5,10) might be ambiguous | constrained |
LWG 2774 | C++11 | (5,10) performed an additional move | eliminated |
[edit] See also
constructs a new std::move_only_function object (public member function of std::move_only_function )
|