std::experimental::function<R(Args...)>::function
|   function() noexcept;  | 
(1) | (library fundamentals TS) | 
|   function( std::nullptr_t ) noexcept;  | 
(2) | (library fundamentals TS) | 
|   function( const function& other );  | 
(3) | (library fundamentals TS) | 
|   function( function&& other );  | 
(4) | (library fundamentals TS) | 
|   template< class F >  function( F f );  | 
(5) | (library fundamentals TS) | 
| (6) | ||
template< class Alloc > function( std::allocator_arg_t, const Alloc& alloc ) noexcept;  | 
(library fundamentals TS) | |
|   function( std::allocator_arg_t, const allocator_type& alloc ) noexcept;  | 
(library fundamentals TS v3) | |
| (7) | ||
template< class Alloc > function( std::allocator_arg_t, const Alloc& alloc,   | 
(library fundamentals TS) | |
|   function( std::allocator_arg_t, const allocator_type& alloc,  std::nullptr_t ) noexcept;  | 
(library fundamentals TS v3) | |
| (8) | ||
template< class Alloc > function( std::allocator_arg_t, const Alloc& alloc,   | 
(library fundamentals TS) | |
|   function( std::allocator_arg_t, const allocator_type& alloc,  const function& other );  | 
(library fundamentals TS v3) | |
| (9) | ||
template< class Alloc > function( std::allocator_arg_t, const Alloc& alloc,   | 
(library fundamentals TS) | |
|   function( std::allocator_arg_t, const allocator_type& alloc,  function&& other );  | 
(library fundamentals TS v3) | |
| (10) | ||
template< class F, class Alloc >  function( std::allocator_arg_t, const Alloc& alloc, F f );  | 
(library fundamentals TS) | |
|   function( std::allocator_arg_t, const allocator_type& alloc, F f );  | 
(library fundamentals TS v3) | |
Constructs a std::experimental::function from a variety of sources.
Args... and return type R.function might use. These constructors treat alloc as a type-erased allocator (see below).(until library fundamentals TS v3)| 
 After construction via (1-5), this->get_memory_resource() returns the same value as std::experimental::pmr::get_default_resource() during construction.  | 
(library fundamentals TS) (until library fundamentals TS v3)  | 
| 
 After construction via (1-3) and (5), *this stores a default constructed std::pmr::polymorphic_allocator<>.  | 
(library fundamentals TS v3) | 
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::experimental::function object, no dynamic allocation takes place. Other large objects may be constructed in dynamic allocated storage and accessed by the std::experimental::function object through a pointer.
If a constructor moves or copies a function object, including an instance of std::experimental::function, then that move or copy is performed by using-allocator construction with allocator this->get_memory_resource()(until library fundamentals TS v3)this->get_allocator()(library fundamentals TS v3).
Type-erased allocator
The constructors of function taking an allocator argument alloc treats that argument as a type-erased allocator. The memory resource pointer used by function to allocate memory is determined using the allocator argument (if specified) as follows:
 Type of alloc
 | 
Value of the memory resource pointer | 
| Non-existent (no allocator specified at time of construction) | The value of std::experimental::pmr::get_default_resource() at time of construction. | 
| std::nullptr_t | The value of std::experimental::pmr::get_default_resource() at time of construction. | 
|  A pointer type convertible to std::experimental::pmr::memory_resource*  | 
static_cast<std::experimental::pmr::memory_resource*>(alloc) | 
|  A specialization of std::experimental::pmr::polymorphic_allocator  | 
alloc.resource() | 
| Any other type meeting the Allocator requirements |  A pointer to a value of type std::experimental::pmr::resource_adaptor<A>(alloc), where A is the type of alloc. The pointer remains valid only for the lifetime of the function object.
 | 
| None of the above | The program is ill-formed. | 
Parameters
| other | - | the function object used to initialize *this | 
| f | - | a callable used to initialize *this | 
| alloc | - | an allocator used for internal memory allocation | 
| Type requirements | ||
 -F must meet the requirements of Callable and CopyConstructible.
 | ||
Exceptions
Example
| This section is incomplete Reason: no example  |