std::allocator_traits man page

std::allocator_traits< _Alloc > — Uniform interface to all allocator types.

Synopsis

Inherits std::__allocator_traits_base.

Inherited by __gnu_cxx::__alloc_traits< _Alloc >.

Public Types

template<typename _Alloc , typename _Up > using __rebind = typename _Alloc::template rebind< _Up >::other

typedef _Alloc allocator_type
The allocator type.
using const_pointer = __detected_or_t< __ptr_rebind< pointer, const value_type >, __c_pointer, _Alloc >
The allocator's const pointer type.
using const_void_pointer = __detected_or_t< __ptr_rebind< pointer, const void >, __cv_pointer, _Alloc >
The allocator's const void pointer type.
using difference_type = __detected_or_t< typename pointer_traits< pointer >::difference_type, __diff_type, _Alloc >
The allocator's difference type.
using is_always_equal = __detected_or_t< typename is_empty< _Alloc >::type, __equal, _Alloc >
Whether all instances of the allocator type compare equal.
using pointer = __detected_or_t< value_type *, __pointer, _Alloc >
The allocator's pointer type.
using propagate_on_container_copy_assignment = __detected_or_t< false_type, __pocca, _Alloc >
How the allocator is propagated on copy assignment.
using propagate_on_container_move_assignment = __detected_or_t< false_type, __pocma, _Alloc >
How the allocator is propagated on move assignment.
using propagate_on_container_swap = __detected_or_t< false_type, __pocs, _Alloc >
How the allocator is propagated on swap.
template<typename _Tp > using rebind_alloc = __alloc_rebind< _Alloc, _Tp >

template<typename _Tp > using rebind_traits = allocator_traits< rebind_alloc< _Tp >>

using size_type = __detected_or_t< typename make_unsigned< difference_type >::type, __size_type, _Alloc >
The allocator's size type.
typedef _Alloc::value_type value_type
The allocated type.
using void_pointer = __detected_or_t< __ptr_rebind< pointer, void >, __v_pointer, _Alloc >
The allocator's void pointer type.

Static Public Member Functions

static pointer allocate (_Alloc &__a, size_type __n)
Allocate memory.
static pointer allocate (_Alloc &__a, size_type __n, const_void_pointer __hint)
Allocate memory.
template<typename _Tp , typename... _Args> static auto construct (_Alloc &__a, _Tp *__p, _Args &&... __args) -> decltype(_S_construct(__a, __p, std::forward< _Args >(__args)...))
Construct an object of type _Tp.
static void deallocate (_Alloc &__a, pointer __p, size_type __n)
Deallocate memory.
template<typename _Tp > static void destroy (_Alloc &__a, _Tp *__p)
Destroy an object of type _Tp.
static size_type max_size (const _Alloc &__a) noexcept
The maximum supported allocation size.
static _Alloc select_on_container_copy_construction (const _Alloc &__rhs)
Obtain an allocator to use when copying a container.

Protected Types

template<typename _Tp > using __c_pointer = typename _Tp::const_pointer

template<typename _Tp > using __cv_pointer = typename _Tp::const_void_pointer

template<typename _Tp > using __diff_type = typename _Tp::difference_type

template<typename _Tp > using __equal = typename _Tp::is_always_equal

template<typename _Tp > using __pocca = typename _Tp::propagate_on_container_copy_assignment

template<typename _Tp > using __pocma = typename _Tp::propagate_on_container_move_assignment

template<typename _Tp > using __pocs = typename _Tp::propagate_on_container_swap

template<typename _Tp > using __pointer = typename _Tp::pointer

template<typename _Tp > using __size_type = typename _Tp::size_type

template<typename _Tp > using __v_pointer = typename _Tp::void_pointer

Detailed Description

template<typename _Alloc>

struct std::allocator_traits< _Alloc >" Uniform interface to all allocator types.

Definition at line 83 of file bits/alloc_traits.h.

Member Typedef Documentation

template<typename _Alloc> typedef _Alloc std::allocator_traits< _Alloc >::allocator_type

The allocator type.

Definition at line 86 of file bits/alloc_traits.h.

template<typename _Alloc> using std::allocator_traits< _Alloc >::const_pointer = __detected_or_t<__ptr_rebind<pointer, const value_type>, __c_pointer, _Alloc>

The allocator's const pointer type. Alloc::const_pointer if that type exists, otherwise pointer_traits<pointer>::rebind<const value_type>

Definition at line 105 of file bits/alloc_traits.h.

template<typename _Alloc> using std::allocator_traits< _Alloc >::const_void_pointer = __detected_or_t<__ptr_rebind<pointer, const void>, __cv_pointer, _Alloc>

The allocator's const void pointer type. Alloc::const_void_pointer if that type exists, otherwise pointer_traits<pointer>::rebind<const void>

Definition at line 124 of file bits/alloc_traits.h.

template<typename _Alloc> using std::allocator_traits< _Alloc >::difference_type = __detected_or_t<typename pointer_traits<pointer>::difference_type, __diff_type, _Alloc>

The allocator's difference type. Alloc::difference_type if that type exists, otherwise pointer_traits<pointer>::difference_type

Definition at line 134 of file bits/alloc_traits.h.

template<typename _Alloc> using std::allocator_traits< _Alloc >::is_always_equal = __detected_or_t<typename is_empty<_Alloc>::type, __equal, _Alloc>

Whether all instances of the allocator type compare equal. Alloc::is_always_equal if that type exists, otherwise is_empty<Alloc>::type

Definition at line 180 of file bits/alloc_traits.h.

template<typename _Alloc> using std::allocator_traits< _Alloc >::pointer = __detected_or_t<value_type*, __pointer, _Alloc>

The allocator's pointer type. Alloc::pointer if that type exists, otherwise value_type*

Definition at line 95 of file bits/alloc_traits.h.

template<typename _Alloc> using std::allocator_traits< _Alloc >::propagate_on_container_copy_assignment = __detected_or_t<false_type, __pocca, _Alloc>

How the allocator is propagated on copy assignment. Alloc::propagate_on_container_copy_assignment if that type exists, otherwise false_type

Definition at line 153 of file bits/alloc_traits.h.

template<typename _Alloc> using std::allocator_traits< _Alloc >::propagate_on_container_move_assignment = __detected_or_t<false_type, __pocma, _Alloc>

How the allocator is propagated on move assignment. Alloc::propagate_on_container_move_assignment if that type exists, otherwise false_type

Definition at line 162 of file bits/alloc_traits.h.

template<typename _Alloc> using std::allocator_traits< _Alloc >::propagate_on_container_swap = __detected_or_t<false_type, __pocs, _Alloc>

How the allocator is propagated on swap. Alloc::propagate_on_container_swap if that type exists, otherwise false_type

Definition at line 171 of file bits/alloc_traits.h.

template<typename _Alloc> using std::allocator_traits< _Alloc >::size_type = __detected_or_t<typename make_unsigned<difference_type>::type, __size_type, _Alloc>

The allocator's size type. Alloc::size_type if that type exists, otherwise make_unsigned<difference_type>::type

Definition at line 144 of file bits/alloc_traits.h.

template<typename _Alloc> typedef _Alloc::value_type std::allocator_traits< _Alloc >::value_type

The allocated type.

Definition at line 88 of file bits/alloc_traits.h.

template<typename _Alloc> using std::allocator_traits< _Alloc >::void_pointer = __detected_or_t<__ptr_rebind<pointer, void>, __v_pointer, _Alloc>

The allocator's void pointer type. Alloc::void_pointer if that type exists, otherwise pointer_traits<pointer>::rebind<void>

Definition at line 114 of file bits/alloc_traits.h.

Member Function Documentation

template<typename _Alloc> static pointer std::allocator_traits< _Alloc >::allocate (_Alloc & __a, size_type __n) [inline], [static]

Allocate memory.

Parameters:

__a An allocator.
__n The number of objects to allocate space for.

Calls a.allocate(n)

Definition at line 280 of file bits/alloc_traits.h.

Referenced by std::__allocate_guarded().

template<typename _Alloc> static pointer std::allocator_traits< _Alloc >::allocate (_Alloc & __a, size_type __n, const_void_pointer __hint) [inline], [static]

Allocate memory.

Parameters:

__a An allocator.
__n The number of objects to allocate space for.
__hint Aid to locality.

Returns:

Memory of suitable size and alignment for n objects of type value_type

Returns a.allocate(n, hint) if that expression is well-formed, otherwise returns a.allocate(n)

Definition at line 295 of file bits/alloc_traits.h.

template<typename _Alloc> template<typename _Tp , typename... _Args> static auto std::allocator_traits< _Alloc >::construct (_Alloc & __a, _Tp * __p, _Args &&... __args) -> decltype(_S_construct(__a, __p, std::forward<_Args>(__args)...))

[inline], [static]"

Construct an object of type _Tp.

Parameters:

__a An allocator.
__p Pointer to memory of suitable size and alignment for Tp
__args Constructor arguments.

Calls __a.construct(__p, std::forward<Args>(__args)...) if that expression is well-formed, otherwise uses placement-new to construct an object of type _Tp at location __p from the arguments __args...

Definition at line 322 of file bits/alloc_traits.h.

template<typename _Alloc> static void std::allocator_traits< _Alloc >::deallocate (_Alloc & __a, pointer __p, size_type __n) [inline], [static]

Deallocate memory.

Parameters:

__a An allocator.
__p Pointer to the memory to deallocate.
__n The number of objects space was allocated for.

Calls a.deallocate(p, n)

Definition at line 307 of file bits/alloc_traits.h.

Referenced by std::__allocated_ptr< _Alloc >::~__allocated_ptr().

template<typename _Alloc> template<typename _Tp > static void std::allocator_traits< _Alloc >::destroy (_Alloc & __a, _Tp * __p) [inline], [static]

Destroy an object of type _Tp.

Parameters:

__a An allocator.
__p Pointer to the object to destroy

Calls __a.destroy(__p) if that expression is well-formed, otherwise calls __p->~_Tp()

Definition at line 335 of file bits/alloc_traits.h.

template<typename _Alloc> static size_type std::allocator_traits< _Alloc >::max_size (const _Alloc & __a) [inline], [static], [noexcept]

The maximum supported allocation size.

Parameters:

__a An allocator.

Returns:

__a.max_size() or numeric_limits<size_type>::max()

Returns __a.max_size() if that expression is well-formed, otherwise returns numeric_limits<size_type>::max()

Definition at line 346 of file bits/alloc_traits.h.

template<typename _Alloc> static _Alloc std::allocator_traits< _Alloc >::select_on_container_copy_construction (const _Alloc & __rhs) [inline], [static]

Obtain an allocator to use when copying a container.

Parameters:

__rhs An allocator.

Returns:

__rhs.select_on_container_copy_construction() or __rhs

Returns __rhs.select_on_container_copy_construction() if that expression is well-formed, otherwise returns __rhs

Definition at line 358 of file bits/alloc_traits.h.

Author

Generated automatically by Doxygen for libstdc++ from the source code.

Info

Fri Sep 16 2016 libstdc++