std::pmr::polymorphic_allocator<T>::allocate

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
T* allocate( std::size_t n ) ;
(since C++17)

Allocates storage for n objects of type T using the underlying memory resource. Equivalent to return static_cast <T* > (resource( ) - >allocate(n * sizeof(T), alignof(T) ) ) ;

Parameters

n - the number of objects to allocate storage for

Return value

A pointer to the allocated storage.

Exceptions

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

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 3038 C++17 allocate might allocate storage of wrong size throws length_error instead
LWG 3237 C++17 the exception thrown by allocate was inconsistent with std::allocator::allocate made consistent

See also

(C++20)
allocate raw aligned memory from the underlying resource
(public member function)
(C++20)
allocates raw memory suitable for an object or an array
(public member function)
(C++20)
allocates and constructs an object
(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)