Namespaces
Variants

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

From cppreference.net
Memory management library
( exposition only* )
Allocators
Uninitialized memory algorithms
Constrained uninitialized memory algorithms
Memory resources
Uninitialized storage (until C++20)
( until C++20* )
( until C++20* )
( until C++20* )

Garbage collector support (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)
(C++11) (until C++23)
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)

Создает новый polymorphic_allocator .

1) Создает polymorphic_allocator , используя возвращаемое значение std:: pmr :: get_default_resource ( ) в качестве базового ресурса памяти.
2,3) Создает polymorphic_allocator используя other. resource ( ) в качестве базового ресурса памяти.
4) Создает polymorphic_allocator , используя r в качестве базового ресурса памяти. Этот конструктор обеспечивает неявное преобразование из std:: pmr :: memory_resource * .

Содержание

Параметры

other - другой polymorphic_allocator для копирования
r - указатель на используемый ресурс памяти. Не может быть нулевым

Исключения

4) Ничего не выбрасывает.

Примечания

Копирование контейнера с использованием polymorphic_allocator не вызывает конструктор копирования аллокатора. Вместо этого новый контейнер будет использовать возвращаемое значение select_on_container_copy_construction (конструктор по умолчанию polymorphic_allocator ) в качестве своего аллокатора.

Смотрите также

создает новый polymorphic_allocator для использования конструктором копирования контейнера
(публичная функция-член)