Scroll to navigation

std::pmr::polymorphic_allocator(3) C++ Standard Libary std::pmr::polymorphic_allocator(3)

NAME

std::pmr::polymorphic_allocator - std::pmr::polymorphic_allocator

Synopsis


Defined in header <memory_resource>
template< class T > (since C++17)
class polymorphic_allocator; (until C++20)
template< class T = std::byte > (since C++20)
class polymorphic_allocator;


The class template std::pmr::polymorphic_allocator is an Allocator which exhibits
different allocation behavior depending upon the std::pmr::memory_resource from
which it is constructed. Since memory_resource uses runtime polymorphism to manage
allocations, different container instances with polymorphic_allocator as their
static allocator type are interoperable, but can behave as if they had different
allocator types.


All specializations of polymorphic_allocator meet the allocator completeness
requirements.


The polymorphic_allocator::construct member function does uses-allocator
construction, so that the elements of a container using a polymorphic_allocator will
use that same allocator for their own allocations. For example, a
std::pmr::vector<std::pmr::string> will use the same memory_resource for the
vector's storage and each string's storage.


For non-polymorphic allocators, similar propagation can be achieved with the help of
std::scoped_allocator_adaptor.

Member types


Member type definition
value_type T

Member functions


constructor constructs a polymorphic_allocator
(public member function)
destructor implicitly declared destructor
(implicitly declared) (public member function)
operator= copy assignment operator is deleted
[deleted] (public member function)

Public member functions


allocate allocate memory
(public member function)
deallocate deallocate memory
(public member function)
construct constructs an object in allocated storage
(public member function)
destroy destroys an object in allocated storage
(deprecated in C++20) (public member function)
(undeprecated in C++26)
allocate_bytes allocate raw aligned memory from the
(C++20) underlying resource
(public member function)
deallocate_bytes free raw memory obtained from allocate_bytes
(C++20) (public member function)
allocate_object allocates raw memory suitable for an object or
(C++20) an array
(public member function)
deallocate_object frees raw memory obtained by allocate_object
(C++20) (public member function)
new_object allocates and constructs an object
(C++20) (public member function)
delete_object destroys and deallocates an object
(C++20) (public member function)
create a new polymorphic_allocator for use by
select_on_container_copy_construction a container's copy constructor
(public member function)
returns a pointer to the underlying memory
resource resource
(public member function)

Non-member functions


operator== compare two polymorphic_allocators
operator!= (function)
(removed in C++20)

Notes


polymorphic_allocator does not propagate on container copy assignment, move
assignment, or swap. As a result, move assignment of a polymorphic_allocator-using
container can throw, and swapping two polymorphic_allocator-using containers whose
allocators do not compare equal results in undefined behavior.


Feature-test macro Value Std Feature
__cpp_lib_polymorphic_allocator 201902L (C++20) std::pmr::polymorphic_allocator<> as
a vocabulary type

See also


memory_resource an abstract interface for classes that encapsulate memory resources
(C++17) (class)

2024.06.10 http://cppreference.com