libstdc++
|
Public Types | |
typedef _Base::allocator_type | allocator_type |
typedef __gnu_debug::_Safe_iterator< _Base_const_iterator, unordered_map > | const_iterator |
typedef __gnu_debug::_Safe_local_iterator< _Base_const_local_iterator, unordered_map > | 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 |
using | insert_return_type = _Node_insert_return< iterator, node_type > |
typedef __gnu_debug::_Safe_iterator< _Base_iterator, unordered_map > | iterator |
typedef _Base::key_equal | key_equal |
typedef _Base::key_type | key_type |
typedef __gnu_debug::_Safe_local_iterator< _Base_local_iterator, unordered_map > | 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_map (_Base_ref __x) | |
template<typename _InputIterator > | |
unordered_map (_InputIterator __first, _InputIterator __last, size_type __n, const allocator_type &__a) | |
template<typename _InputIterator > | |
unordered_map (_InputIterator __first, _InputIterator __last, size_type __n, const hasher &__hf, const allocator_type &__a) | |
template<typename _InputIterator > | |
unordered_map (_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_map (const allocator_type &__a) | |
unordered_map (const unordered_map &)=default | |
unordered_map (const unordered_map &__umap, const allocator_type &__a) | |
unordered_map (initializer_list< value_type > __l, size_type __n, const allocator_type &__a) | |
unordered_map (initializer_list< value_type > __l, size_type __n, const hasher &__hf, const allocator_type &__a) | |
unordered_map (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_map (size_type __n, const allocator_type &__a) | |
unordered_map (size_type __n, const hasher &__hf, const allocator_type &__a) | |
unordered_map (size_type __n, const hasher &__hf=hasher(), const key_equal &__eql=key_equal(), const allocator_type &__a=allocator_type()) | |
unordered_map (unordered_map &&)=default | |
unordered_map (unordered_map &&__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> | |
std::pair< iterator, bool > | 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> | |
std::pair< iterator, bool > | insert (_Pair &&__obj) |
std::pair< iterator, bool > | 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) |
insert_return_type | insert (node_type &&__nh) |
void | insert (std::initializer_list< value_type > __l) |
std::pair< iterator, bool > | insert (value_type &&__x) |
template<typename _Obj > | |
pair< iterator, bool > | insert_or_assign (const key_type &__k, _Obj &&__obj) |
template<typename _Obj > | |
iterator | insert_or_assign (const_iterator __hint, const key_type &__k, _Obj &&__obj) |
template<typename _Obj > | |
iterator | insert_or_assign (const_iterator __hint, key_type &&__k, _Obj &&__obj) |
template<typename _Obj > | |
pair< iterator, bool > | insert_or_assign (key_type &&__k, _Obj &&__obj) |
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_map & | operator= (const unordered_map &)=default |
unordered_map & | operator= (initializer_list< value_type > __l) |
unordered_map & | operator= (unordered_map &&)=default |
void | swap (unordered_map &__x) noexcept(noexcept(declval< _Base & >().swap(__x))) |
template<typename... _Args> | |
pair< iterator, bool > | try_emplace (const key_type &__k, _Args &&... __args) |
template<typename... _Args> | |
iterator | try_emplace (const_iterator __hint, const key_type &__k, _Args &&... __args) |
template<typename... _Args> | |
iterator | try_emplace (const_iterator __hint, key_type &&__k, _Args &&... __args) |
template<typename... _Args> | |
pair< iterator, bool > | try_emplace (key_type &&__k, _Args &&... __args) |
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_map with safety/checking/debug instrumentation.
Definition at line 63 of file debug/unordered_map.
typedef _Base::allocator_type std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::allocator_type |
Definition at line 96 of file debug/unordered_map.
typedef __gnu_debug::_Safe_iterator< _Base_const_iterator, unordered_map> std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::const_iterator |
Definition at line 109 of file debug/unordered_map.
typedef __gnu_debug::_Safe_local_iterator< _Base_const_local_iterator, unordered_map> std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::const_local_iterator |
Definition at line 113 of file debug/unordered_map.
typedef _Base::const_pointer std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::const_pointer |
Definition at line 103 of file debug/unordered_map.
typedef _Base::const_reference std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::const_reference |
Definition at line 105 of file debug/unordered_map.
typedef _Base::difference_type std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::difference_type |
Definition at line 114 of file debug/unordered_map.
typedef _Base::hasher std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::hasher |
Definition at line 94 of file debug/unordered_map.
using std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::insert_return_type = _Node_insert_return<iterator, node_type> |
Definition at line 525 of file debug/unordered_map.
typedef __gnu_debug::_Safe_iterator< _Base_iterator, unordered_map> std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::iterator |
Definition at line 107 of file debug/unordered_map.
typedef _Base::key_equal std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::key_equal |
Definition at line 95 of file debug/unordered_map.
typedef _Base::key_type std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::key_type |
Definition at line 98 of file debug/unordered_map.
typedef __gnu_debug::_Safe_local_iterator< _Base_local_iterator, unordered_map> std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::local_iterator |
Definition at line 111 of file debug/unordered_map.
typedef _Base::mapped_type std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::mapped_type |
Definition at line 100 of file debug/unordered_map.
using std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::node_type = typename _Base::node_type |
Definition at line 524 of file debug/unordered_map.
typedef _Base::pointer std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::pointer |
Definition at line 102 of file debug/unordered_map.
typedef _Base::reference std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::reference |
Definition at line 104 of file debug/unordered_map.
typedef _Base::size_type std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::size_type |
Definition at line 93 of file debug/unordered_map.
typedef _Base::value_type std::__debug::unordered_map< _Key, _Tp, _Hash, _Pred, _Alloc >::value_type |
Definition at line 99 of file debug/unordered_map.
|
inlineexplicit |
Definition at line 119 of file debug/unordered_map.
|
inline |
Definition at line 126 of file debug/unordered_map.
|
inline |
Definition at line 138 of file debug/unordered_map.
|
inlineexplicit |
Definition at line 144 of file debug/unordered_map.
|
inline |
Definition at line 147 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 151 of file debug/unordered_map.
|
inline |
Definition at line 157 of file debug/unordered_map.
|
inline |
Definition at line 164 of file debug/unordered_map.
|
inline |
Definition at line 168 of file debug/unordered_map.
|
inline |
Definition at line 175 of file debug/unordered_map.
|
inline |
Definition at line 182 of file debug/unordered_map.
|
inline |
Definition at line 189 of file debug/unordered_map.
|
inline |
Definition at line 195 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 722 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 719 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 243 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 239 of file debug/unordered_map.
|
inline |
Definition at line 264 of file debug/unordered_map.
|
inline |
Definition at line 278 of file debug/unordered_map.
|
inline |
Definition at line 310 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 255 of file debug/unordered_map.
|
inline |
Definition at line 292 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 259 of file debug/unordered_map.
|
inline |
Definition at line 299 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 232 of file debug/unordered_map.
|
inline |
Definition at line 331 of file debug/unordered_map.
|
inline |
Definition at line 341 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 251 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 247 of file debug/unordered_map.
|
inline |
Definition at line 271 of file debug/unordered_map.
|
inline |
Definition at line 285 of file debug/unordered_map.
|
inline |
Definition at line 633 of file debug/unordered_map.
|
inline |
Definition at line 652 of file debug/unordered_map.
|
inline |
Definition at line 622 of file debug/unordered_map.
|
inline |
Definition at line 641 of file debug/unordered_map.
|
inline |
Definition at line 683 of file debug/unordered_map.
|
inline |
Definition at line 663 of file debug/unordered_map.
|
inline |
Definition at line 697 of file debug/unordered_map.
|
inline |
Definition at line 676 of file debug/unordered_map.
|
inline |
Definition at line 690 of file debug/unordered_map.
|
inline |
Definition at line 535 of file debug/unordered_map.
|
inline |
Definition at line 528 of file debug/unordered_map.
|
inline |
Definition at line 599 of file debug/unordered_map.
|
inline |
Definition at line 612 of file debug/unordered_map.
|
inline |
Definition at line 591 of file debug/unordered_map.
|
inline |
Definition at line 604 of file debug/unordered_map.
|
inline |
Definition at line 428 of file debug/unordered_map.
|
inline |
Definition at line 375 of file debug/unordered_map.
|
inline |
Definition at line 352 of file debug/unordered_map.
|
inline |
Definition at line 409 of file debug/unordered_map.
|
inline |
Definition at line 384 of file debug/unordered_map.
|
inline |
Definition at line 552 of file debug/unordered_map.
|
inline |
Definition at line 396 of file debug/unordered_map.
|
inline |
Definition at line 544 of file debug/unordered_map.
|
inline |
Definition at line 419 of file debug/unordered_map.
|
inline |
Definition at line 363 of file debug/unordered_map.
|
inline |
Definition at line 485 of file debug/unordered_map.
|
inline |
Definition at line 503 of file debug/unordered_map.
|
inline |
Definition at line 514 of file debug/unordered_map.
|
inline |
Definition at line 494 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 319 of file debug/unordered_map.
|
inline |
Definition at line 323 of file debug/unordered_map.
|
inline |
Definition at line 569 of file debug/unordered_map.
|
inline |
Definition at line 560 of file debug/unordered_map.
|
inline |
Definition at line 583 of file debug/unordered_map.
|
inline |
Definition at line 574 of file debug/unordered_map.
|
inline |
Definition at line 211 of file debug/unordered_map.
|
inlinenoexcept |
Definition at line 224 of file debug/unordered_map.
|
inline |
Definition at line 446 of file debug/unordered_map.
|
inline |
Definition at line 464 of file debug/unordered_map.
|
inline |
Definition at line 475 of file debug/unordered_map.
|
inline |
Definition at line 455 of file debug/unordered_map.
|
friend |
Definition at line 80 of file debug/unordered_map.
|
friend |
Definition at line 82 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().