std::pmr::polymorphic_allocator<T>::new_object
|
|
|
Member functions | ||||
(C++20/26*)
|
||||
polymorphic_allocator::new_object
(C++20)
|
||||
Non-member functions | ||||
(until C++20)
|
template
<
class U, class... CtorArgs
>
U* new_object( CtorArgs&&... ctor_args ) ; |
(since C++20) | |
Allocates and constructs an object of type U
.
Given alloc
is a
std::pmr::polymorphic_allocator
<T>
U* p = alloc.new_object<U>(std::forward<CtorArgs>(ctor_args)...);
is equivalent to
U* p = alloc.allocate_object<U>(); try { alloc.construct(p, std::forward<CtorArgs>(ctor_args)...); } catch (...) { alloc.deallocate_object(p); throw; }
Parameters
ctor_args | - | the arguments to forward to the constructor of U
|
Return value
A pointer to the allocated and constructed object.
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> , and having to call allocate, construct, and deallocate
Since U
is not deduced, it must be provided as a template argument when calling this function.
Exceptions
May throw any exceptions thrown by the call to allocate_object or the constructor of U
.
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) |
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 ) |