CARVIEW |
Select Language
HTTP/1.1 200 OK
Server: nginx
Date: Wed, 23 Jul 2025 15:15:19 GMT
Content-Type: text/html; charset=utf-8
Transfer-Encoding: chunked
Connection: keep-alive
ETag: W/"9688-Azh/ChJBejDWgq56Ko4lBUgnZ3o"
Content-Encoding: gzip
This template supplies a uniform interface for allocator types.
The non-specialized version provides an interface that allows to use as allocator just any class that provides at least a public member type value_type and public member functions allocate and deallocate (see example).
But any class type can be used as allocator by specializing this class to give it an interface.
Possible output:
Reference
C library:
- <cassert> (assert.h)
- <cctype> (ctype.h)
- <cerrno> (errno.h)
-
<cfenv> (fenv.h)C++11
- <cfloat> (float.h)
-
<cinttypes> (inttypes.h)C++11
- <ciso646> (iso646.h)
- <climits> (limits.h)
- <clocale> (locale.h)
- <cmath> (math.h)
- <csetjmp> (setjmp.h)
- <csignal> (signal.h)
- <cstdarg> (stdarg.h)
-
<cstdbool> (stdbool.h)C++11
- <cstddef> (stddef.h)
-
<cstdint> (stdint.h)C++11
- <cstdio> (stdio.h)
- <cstdlib> (stdlib.h)
- <cstring> (string.h)
-
<ctgmath> (tgmath.h)C++11
- <ctime> (time.h)
-
<cuchar> (uchar.h)C++11
- <cwchar> (wchar.h)
- <cwctype> (wctype.h)
Containers:
-
<array>C++11
- <deque>
-
<forward_list>C++11
- <list>
- <map>
- <queue>
- <set>
- <stack>
-
<unordered_map>C++11
-
<unordered_set>C++11
- <vector>
-
Input/Output:
Multi-threading:
-
<atomic>C++11
-
<condition_variable>C++11
-
<future>C++11
-
<mutex>C++11
-
<thread>C++11
-
Other:
- <algorithm>
- <bitset>
-
<chrono>C++11
-
<codecvt>C++11
- <complex>
- <exception>
- <functional>
-
<initializer_list>C++11
- <iterator>
- <limits>
- <locale>
- <memory>
- <new>
- <numeric>
-
<random>C++11
-
<ratio>C++11
-
<regex>C++11
- <stdexcept>
- <string>
-
<system_error>C++11
-
<tuple>C++11
-
<type_traits>C++11
-
<typeindex>C++11
- <typeinfo>
- <utility>
- <valarray>
<memory>
classes
- allocator
-
allocator_arg_tC++11
-
allocator_traitsC++11
- auto_ptr
- auto_ptr_ref
-
bad_weak_ptrC++11
-
default_deleteC++11
-
enable_shared_from_thisC++11
-
owner_lessC++11
-
pointer_traitsC++11
- raw_storage_iterator
-
shared_ptrC++11
-
unique_ptrC++11
-
uses_allocatorC++11
-
weak_ptrC++11
enum classes
-
pointer_safetyC++11
-
functions
-
addressofC++11
-
alignC++11
-
allocate_sharedC++11
-
const_pointer_castC++11
-
declare_no_pointersC++11
-
declare_reachableC++11
-
dynamic_pointer_castC++11
-
get_deleterC++11
-
get_pointer_safetyC++11
- get_temporary_buffer
-
make_sharedC++11
- return_temporary_buffer
-
static_pointer_castC++11
-
undeclare_no_pointersC++11
-
undeclare_reachableC++11
- uninitialized_copy
-
uninitialized_copy_nC++11
- uninitialized_fill
- uninitialized_fill_n
-
objects
-
allocator_argC++11
-
allocator_traits
static member functions
class template
<memory>
std::allocator_traits
template <class Alloc> struct allocator_traits;
Allocator traits
The non-specialized version provides an interface that allows to use as allocator just any class that provides at least a public member type value_type and public member functions allocate and deallocate (see example).
But any class type can be used as allocator by specializing this class to give it an interface.
Template parameters
- Alloc
- The allocator type, aliased as member type allocator_type.
Member types
The following aliases are member types of allocator_traits. Any specialization shall also define these member types:member type | definition in unspecialized allocator_traits |
---|---|
allocator_type | the template parameter (Alloc) |
value_type | allocator_type::value_type |
pointer | allocator_type::pointer (if defined) value_type* (otherwise) |
const_pointer | allocator_type::const_pointer (if defined) pointer_traits<pointer>::rebind<const value_type> (otherwise) |
void_pointer | allocator_type::void_pointer (if defined) pointer_traits<pointer>::rebind<void> (otherwise) |
const_void_pointer | allocator_type::const_void_pointer (if defined) pointer_traits<pointer>::rebind<const void> (otherwise) |
difference_type | allocator_type::difference_type (if defined) pointer_traits<pointer>::difference_type (otherwise) |
size_type | allocator_type::size_type (if defined) make_unsigned<difference_type>::type (otherwise) |
propagate_on_container_copy_assignment | allocator_type::propagate_on_container_copy_assignment (if defined) false_type (otherwise) |
propagate_on_container_move_assignment | allocator_type::propagate_on_container_move_assignment (if defined) false_type (otherwise) |
propagate_on_container_swap | allocator_type::propagate_on_container_swap (if defined) false_type (otherwise) |
rebind_alloc<T> | allocator_type::rebind<T>::other (if defined) AllocTemplate<T,Args> (if Alloc is an instantiation of the form AllocTemplate<U,Args>, where Args are zero or more type arguments) * Note: this is an alias template |
rebind_traits<T> | allocator_traits<rebind_alloc<T>> * Note: this is an alias template |
Static member functions
- allocate
- Allocate block of storage (public static member function)
- deallocate
- Release block of storage (public static member function)
- construct
- Construct an element (public static member function)
- destroy
- Destroy object (public static member function)
- max_size
- Maximum size possible to allocate (public static member function)
- select_on_container_copy_construction
- Select on container copy construction (public static member function)
Example
|
|
Possible output:
10 20 30 |
Home page | Privacy policy
© cplusplus.com, 2000-2025 - All rights reserved - v3.3.4s
Spotted an error? contact us
© cplusplus.com, 2000-2025 - All rights reserved - v3.3.4s
Spotted an error? contact us