std::pmr::polymorphic_allocator<T>::allocate_object

From cppreference.com
Memory management library
(exposition only*)
Uninitialized memory algorithms
(C++17)
(C++17)
(C++17)
(C++20)
Constrained uninitialized
memory algorithms
(C++20)
C Library

Allocators
(C++11)
(C++11)
Memory resources
Garbage collection support
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
(C++11)(until C++23)
Uninitialized storage
(until C++20*)
(until C++20*)
(until C++20*)
Explicit lifetime management
template < class U >
U* allocate_object( std::size_t n = 1 ) ;
(since C++20)

Allocates storage for n objects of type U using the underlying memory resource.

If std::numeric_limits < std::size_t > :: max ( ) / sizeof(U) < , throws std::bad_array_new_length, otherwise equivalent to return static_cast <U* > (allocate_bytes(n * sizeof(U), alignof(U) ) ) ;

Parameters

n - the number of objects to allocate storage for

Return value

A pointer to the allocated storage.

Notes

This function was introduced for use with the fully-specialized allocator std::pmr::polymorphic_allocator <> , but it may be useful in any specialization as a shortcut to avoid having to rebind from std::pmr::polymorphic_allocator <T> to std::pmr::polymorphic_allocator <U>

Since U is not deduced, it must be provided as a template argument when calling this function.

Exceptions

Throws std::bad_array_new_length if n > std::numeric_limits < std::size_t > :: max ( ) / sizeof(U) ; may also be any exceptions thrown by the call to resource()->allocate

See also

(C++20)
allocate raw aligned memory from the underlying resource
(public member function)
(C++20)
allocates and constructs an object
(public member function)
allocate memory
(public member function)
[static]
allocates uninitialized storage using the allocator
(public static member function of std::allocator_traits<Alloc>)
allocates memory
(public member function of std::pmr::memory_resource)