std::pmr::polymorphic_allocator<T>::polymorphic_allocator
From cppreference.com
                    
                                        
                    < cpp | memory | polymorphic allocator
                    
                                                            
                    |   polymorphic_allocator() noexcept;  | 
(1) | |
|   polymorphic_allocator( const polymorphic_allocator& other ) = default;  | 
(2) | |
|   template< class U >  polymorphic_allocator( const polymorphic_allocator<U>& other ) noexcept;  | 
(3) | |
|   polymorphic_allocator( std::pmr::memory_resource* r );  | 
(4) | |
Constructs a new polymorphic_allocator.
1) Constructs a 
polymorphic_allocator using the return value of std::pmr::get_default_resource() as the underlying memory resource.2,3) Constructs a 
polymorphic_allocator using other.resource() as the underlying memory resource.4) Constructs a 
polymorphic_allocator using r as the underlying memory resource. This constructor provides an implicit conversion from std::pmr::memory_resource*.Parameters
| other | - |  another polymorphic_allocator to copy from
 | 
| r | - | pointer to the memory resource to use. May not be null | 
Exceptions
4) Throws nothing.
Notes
Copying a container using a polymorphic_allocator will not call the allocator's copy constructor. Instead, the new container will use the return value of select_on_container_copy_construction (a default-constructed polymorphic_allocator) as its allocator.
See also
  create a new polymorphic_allocator for use by a container's copy constructor (public member function)  |