libstdc++
|
Public Types | |
typedef _Base::allocator_type | allocator_type |
typedef __gnu_debug::_Safe_iterator< _Base_const_iterator, unordered_multimap > | const_iterator |
typedef __gnu_debug::_Safe_local_iterator< _Base_const_local_iterator, unordered_multimap > | const_local_iterator |
typedef _Base::const_pointer | const_pointer |
typedef _Base::const_reference | const_reference |
typedef _Base::difference_type | difference_type |
typedef _Base::hasher | hasher |
typedef __gnu_debug::_Safe_iterator< _Base_iterator, unordered_multimap > | iterator |
typedef _Base::key_equal | key_equal |
typedef _Base::key_type | key_type |
typedef __gnu_debug::_Safe_local_iterator< _Base_local_iterator, unordered_multimap > | local_iterator |
typedef _Base::mapped_type | mapped_type |
using | node_type = typename _Base::node_type |
typedef _Base::pointer | pointer |
typedef _Base::reference | reference |
typedef _Base::size_type | size_type |
typedef _Base::value_type | value_type |
Public Member Functions | |
unordered_multimap (_Base_ref __x) | |
template<typename _InputIterator > | |
unordered_multimap (_InputIterator __first, _InputIterator __last, size_type __n, const allocator_type &__a) | |
template<typename _InputIterator > | |
unordered_multimap (_InputIterator __first, _InputIterator __last, size_type __n, const hasher &__hf, const allocator_type &__a) | |
template<typename _InputIterator > | |
unordered_multimap (_InputIterator __first, _InputIterator __last, size_type __n=0, const hasher &__hf=hasher(), const key_equal &__eql=key_equal(), const allocator_type &__a=allocator_type()) | |
unordered_multimap (const allocator_type &__a) | |
unordered_multimap (const unordered_multimap &)=default | |
unordered_multimap (const unordered_multimap &__umap, const allocator_type &__a) | |
unordered_multimap (initializer_list< value_type > __l, size_type __n, const allocator_type &__a) | |
unordered_multimap (initializer_list< value_type > __l, size_type __n, const hasher &__hf, const allocator_type &__a) | |
unordered_multimap (initializer_list< value_type > __l, size_type __n=0, const hasher &__hf=hasher(), const key_equal &__eql=key_equal(), const allocator_type &__a=allocator_type()) | |
unordered_multimap (size_type __n, const allocator_type &__a) | |
unordered_multimap (size_type __n, const hasher &__hf, const allocator_type &__a) | |
unordered_multimap (size_type __n, const hasher &__hf=hasher(), const key_equal &__eql=key_equal(), const allocator_type &__a=allocator_type()) | |
unordered_multimap (unordered_multimap &&)=default | |
unordered_multimap (unordered_multimap &&__umap, const allocator_type &__a) noexcept(noexcept(_Base(std::move(__umap), __a))) | |
const _Base & | _M_base () const noexcept |
_Base & | _M_base () noexcept |
void | _M_invalidate_all () |
void | _M_invalidate_if (_Predicate __pred) |
void | _M_invalidate_local_if (_Predicate __pred) |
const_iterator | begin () const noexcept |
iterator | begin () noexcept |
local_iterator | begin (size_type __b) |
const_local_iterator | begin (size_type __b) const |
size_type | bucket_size (size_type __b) const |
const_iterator | cbegin () const noexcept |
const_local_iterator | cbegin (size_type __b) const |
const_iterator | cend () const noexcept |
const_local_iterator | cend (size_type __b) const |
void | clear () noexcept |
template<typename... _Args> | |
iterator | emplace (_Args &&... __args) |
template<typename... _Args> | |
iterator | emplace_hint (const_iterator __hint, _Args &&... __args) |
const_iterator | end () const noexcept |
iterator | end () noexcept |
local_iterator | end (size_type __b) |
const_local_iterator | end (size_type __b) const |
template<typename _Kt , typename = std::__has_is_transparent_t<_Hash, _Kt>, typename = std::__has_is_transparent_t<_Pred, _Kt>> | |
std::pair< iterator, iterator > | equal_range (const _Kt &__k) |
template<typename _Kt , typename = std::__has_is_transparent_t<_Hash, _Kt>, typename = std::__has_is_transparent_t<_Pred, _Kt>> | |
std::pair< const_iterator, const_iterator > | equal_range (const _Kt &__k) const |
std::pair< iterator, iterator > | equal_range (const key_type &__key) |
std::pair< const_iterator, const_iterator > | equal_range (const key_type &__key) const |
_Base_iterator | erase (_Base_const_iterator __it) |
size_type | erase (const key_type &__key) |
iterator | erase (const_iterator __first, const_iterator __last) |
iterator | erase (const_iterator __it) |
iterator | erase (iterator __it) |
node_type | extract (const key_type &__key) |
node_type | extract (const_iterator __position) |
template<typename _Kt , typename = std::__has_is_transparent_t<_Hash, _Kt>, typename = std::__has_is_transparent_t<_Pred, _Kt>> | |
iterator | find (const _Kt &__k) |
template<typename _Kt , typename = std::__has_is_transparent_t<_Hash, _Kt>, typename = std::__has_is_transparent_t<_Pred, _Kt>> | |
const_iterator | find (const _Kt &__k) const |
iterator | find (const key_type &__key) |
const_iterator | find (const key_type &__key) const |
template<typename _InputIterator > | |
void | insert (_InputIterator __first, _InputIterator __last) |
template<typename _Pair , typename = typename std::enable_if<std::is_constructible<value_type, _Pair&&>::value>::type> | |
iterator | insert (_Pair &&__obj) |
iterator | insert (const value_type &__obj) |
template<typename _Pair , typename = typename std::enable_if<std::is_constructible<value_type, _Pair&&>::value>::type> | |
iterator | insert (const_iterator __hint, _Pair &&__obj) |
iterator | insert (const_iterator __hint, const value_type &__obj) |
iterator | insert (const_iterator __hint, node_type &&__nh) |
iterator | insert (const_iterator __hint, value_type &&__x) |
iterator | insert (node_type &&__nh) |
void | insert (std::initializer_list< value_type > __l) |
iterator | insert (value_type &&__x) |
float | max_load_factor () const noexcept |
void | max_load_factor (float __f) |
template<typename _H2 , typename _P2 > | |
void | merge (unordered_map< _Key, _Tp, _H2, _P2, _Alloc > &&__source) |
template<typename _H2 , typename _P2 > | |
void | merge (unordered_map< _Key, _Tp, _H2, _P2, _Alloc > &__source) |
template<typename _H2 , typename _P2 > | |
void | merge (unordered_multimap< _Key, _Tp, _H2, _P2, _Alloc > &&__source) |
template<typename _H2 , typename _P2 > | |
void | merge (unordered_multimap< _Key, _Tp, _H2, _P2, _Alloc > &__source) |
unordered_multimap & | operator= (const unordered_multimap &)=default |
unordered_multimap & | operator= (initializer_list< value_type > __l) |
unordered_multimap & | operator= (unordered_multimap &&)=default |
void | swap (unordered_multimap &__x) noexcept(noexcept(declval< _Base & >().swap(__x))) |
Public Attributes | |
_Safe_iterator_base * | _M_const_iterators |
_Safe_iterator_base * | _M_const_local_iterators |
_Safe_iterator_base * | _M_iterators |
_Safe_iterator_base * | _M_local_iterators |
unsigned int | _M_version |
Protected Member Functions | |
void | _M_detach_all () |
void | _M_detach_singular () |
__gnu_cxx::__mutex & | _M_get_mutex () throw () |
void | _M_invalidate_all () const |
void | _M_invalidate_locals () |
void | _M_revalidate_singular () |
void | _M_swap (_Safe_container &__x) noexcept |
void | _M_swap (_Safe_sequence_base &__x) noexcept |
void | _M_swap (_Safe_unordered_container_base &__x) noexcept |
Static Protected Member Functions | |
static _UContMergeGuard< _Source, _UContInvalidatePred< _ExtractKey, _Source > > | _S_uc_guard (_ExtractKey, _Source &__src) |
static _UContMergeGuard< _Source, _UMContInvalidatePred< _ExtractKey, _Source > > | _S_umc_guard (_ExtractKey, _Source &__src) |
Friends | |
template<typename _ItT , typename _SeqT , typename _CatT > | |
class | ::__gnu_debug::_Safe_iterator |
template<typename _ItT , typename _SeqT > | |
class | ::__gnu_debug::_Safe_local_iterator |
Class std::unordered_multimap with safety/checking/debug instrumentation.
Definition at line 873 of file debug/unordered_map.
typedef _Base::allocator_type std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::allocator_type |
Definition at line 906 of file debug/unordered_map.
typedef __gnu_debug::_Safe_iterator< _Base_const_iterator, unordered_multimap> std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::const_iterator |
Definition at line 919 of file debug/unordered_map.
typedef __gnu_debug::_Safe_local_iterator< _Base_const_local_iterator, unordered_multimap> std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::const_local_iterator |
Definition at line 923 of file debug/unordered_map.
typedef _Base::const_pointer std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::const_pointer |
Definition at line 913 of file debug/unordered_map.
typedef _Base::const_reference std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::const_reference |
Definition at line 915 of file debug/unordered_map.
typedef _Base::difference_type std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::difference_type |
Definition at line 924 of file debug/unordered_map.
typedef _Base::hasher std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::hasher |
Definition at line 904 of file debug/unordered_map.
typedef __gnu_debug::_Safe_iterator< _Base_iterator, unordered_multimap> std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::iterator |
Definition at line 917 of file debug/unordered_map.
typedef _Base::key_equal std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::key_equal |
Definition at line 905 of file debug/unordered_map.
typedef _Base::key_type std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::key_type |
Definition at line 908 of file debug/unordered_map.
typedef __gnu_debug::_Safe_local_iterator< _Base_local_iterator, unordered_multimap> std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::local_iterator |
Definition at line 921 of file debug/unordered_map.
typedef _Base::mapped_type std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::mapped_type |
Definition at line 910 of file debug/unordered_map.
using std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::node_type = typename _Base::node_type |
Definition at line 1245 of file debug/unordered_map.
typedef _Base::pointer std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::pointer |
Definition at line 912 of file debug/unordered_map.
typedef _Base::reference std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::reference |
Definition at line 914 of file debug/unordered_map.
typedef _Base::size_type std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::size_type |
Definition at line 903 of file debug/unordered_map.
typedef _Base::value_type std::__debug::unordered_multimap< _Key, _Tp, _Hash, _Pred, _Alloc >::value_type |
Definition at line 909 of file debug/unordered_map.
|
inlineexplicit |
Definition at line 929 of file debug/unordered_map.
|
inline |
Definition at line 936 of file debug/unordered_map.
|
inline |
Definition at line 948 of file debug/unordered_map.
|
inlineexplicit |
Definition at line 954 of file debug/unordered_map.
|
inline |
Definition at line 957 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 961 of file debug/unordered_map.
|
inline |
Definition at line 967 of file debug/unordered_map.
|
inline |
Definition at line 974 of file debug/unordered_map.
|
inline |
Definition at line 978 of file debug/unordered_map.
|
inline |
Definition at line 984 of file debug/unordered_map.
|
inline |
Definition at line 991 of file debug/unordered_map.
|
inline |
Definition at line 997 of file debug/unordered_map.
|
inline |
Definition at line 1003 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 1439 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 1436 of file debug/unordered_map.
|
protectedinherited |
Detach all iterators, leaving them singular.
|
protectedinherited |
Detach all singular iterators.
|
protectedinherited |
For use in _Safe_sequence.
Referenced by __gnu_debug::_Safe_sequence< _Sequence >::_M_transfer_from_if().
|
inlineinherited |
Definition at line 166 of file safe_unordered_container.h.
|
inlineprotectedinherited |
Invalidates all iterators.
Definition at line 256 of file safe_base.h.
References __gnu_debug::_Safe_sequence_base::_M_version.
|
inherited |
Invalidates all iterators x
that reference this container, are not singular, and for which __pred(x)
returns true
. __pred
will be invoked with the normal iterators nested in the safe ones.
Definition at line 180 of file safe_unordered_container.tcc.
|
inherited |
Invalidates all local iterators x
that reference this container, are not singular, and for which __pred(x)
returns true
. __pred
will be invoked with the normal local iterators nested in the safe ones.
Definition at line 188 of file safe_unordered_container.tcc.
|
inlineprotectedinherited |
Definition at line 67 of file safe_unordered_container.h.
|
protectedinherited |
Revalidates all attached singular iterators. This method may be used to validate iterators that were invalidated before (but for some reason, such as an exception, need to become valid again).
|
inlineprotectednoexceptinherited |
Definition at line 117 of file safe_container.h.
|
protectednoexceptinherited |
Swap this sequence with the given sequence. This operation also swaps ownership of the iterators, so that when the operation is complete all iterators that originally referenced one container now reference the other container.
|
protectednoexceptinherited |
Swap this container with the given container. This operation also swaps ownership of the iterators, so that when the operation is complete all iterators that originally referenced one container now reference the other container.
|
inlinestaticprotectedinherited |
Definition at line 148 of file safe_unordered_container.h.
|
inlinestaticprotectedinherited |
Definition at line 157 of file safe_unordered_container.h.
|
inlinenoexcept |
Definition at line 1050 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 1046 of file debug/unordered_map.
|
inline |
Definition at line 1071 of file debug/unordered_map.
|
inline |
Definition at line 1085 of file debug/unordered_map.
|
inline |
Definition at line 1117 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 1062 of file debug/unordered_map.
|
inline |
Definition at line 1099 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 1066 of file debug/unordered_map.
|
inline |
Definition at line 1106 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 1039 of file debug/unordered_map.
|
inline |
Definition at line 1136 of file debug/unordered_map.
|
inline |
Definition at line 1146 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 1058 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 1054 of file debug/unordered_map.
|
inline |
Definition at line 1078 of file debug/unordered_map.
|
inline |
Definition at line 1092 of file debug/unordered_map.
|
inline |
Definition at line 1349 of file debug/unordered_map.
|
inline |
Definition at line 1368 of file debug/unordered_map.
|
inline |
Definition at line 1338 of file debug/unordered_map.
|
inline |
Definition at line 1357 of file debug/unordered_map.
|
inline |
Definition at line 1400 of file debug/unordered_map.
|
inline |
Definition at line 1376 of file debug/unordered_map.
|
inline |
Definition at line 1414 of file debug/unordered_map.
|
inline |
Definition at line 1393 of file debug/unordered_map.
|
inline |
Definition at line 1407 of file debug/unordered_map.
|
inline |
Definition at line 1255 of file debug/unordered_map.
|
inline |
Definition at line 1248 of file debug/unordered_map.
|
inline |
Definition at line 1315 of file debug/unordered_map.
|
inline |
Definition at line 1328 of file debug/unordered_map.
|
inline |
Definition at line 1307 of file debug/unordered_map.
|
inline |
Definition at line 1320 of file debug/unordered_map.
|
inline |
Definition at line 1229 of file debug/unordered_map.
|
inline |
Definition at line 1202 of file debug/unordered_map.
|
inline |
Definition at line 1157 of file debug/unordered_map.
|
inline |
Definition at line 1214 of file debug/unordered_map.
|
inline |
Definition at line 1177 of file debug/unordered_map.
|
inline |
Definition at line 1268 of file debug/unordered_map.
|
inline |
Definition at line 1189 of file debug/unordered_map.
|
inline |
Definition at line 1264 of file debug/unordered_map.
|
inline |
Definition at line 1224 of file debug/unordered_map.
|
inline |
Definition at line 1168 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 1124 of file debug/unordered_map.
|
inline |
Definition at line 1128 of file debug/unordered_map.
|
inline |
Definition at line 1299 of file debug/unordered_map.
|
inline |
Definition at line 1290 of file debug/unordered_map.
|
inline |
Definition at line 1285 of file debug/unordered_map.
|
inline |
Definition at line 1276 of file debug/unordered_map.
|
inline |
Definition at line 1018 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 1031 of file debug/unordered_map.
|
friend |
Definition at line 890 of file debug/unordered_map.
|
friend |
Definition at line 892 of file debug/unordered_map.
|
inherited |
The list of constant iterators that reference this container.
Definition at line 197 of file safe_base.h.
Referenced by __gnu_debug::_Safe_sequence< _Sequence >::_M_transfer_from_if().
|
inherited |
The list of constant local iterators that reference this container.
Definition at line 130 of file safe_unordered_base.h.
|
inherited |
The list of mutable iterators that reference this container.
Definition at line 194 of file safe_base.h.
Referenced by __gnu_debug::_Safe_sequence< _Sequence >::_M_transfer_from_if().
|
inherited |
The list of mutable local iterators that reference this container.
Definition at line 127 of file safe_unordered_base.h.
|
mutableinherited |
The container version number. This number may never be 0.
Definition at line 200 of file safe_base.h.
Referenced by __gnu_debug::_Safe_sequence_base::_M_invalidate_all().