libstdc++
|
Public Types | |
typedef _Base::allocator_type | allocator_type |
typedef __gnu_debug::_Safe_iterator< _Base_const_iterator, unordered_set > | const_iterator |
typedef __gnu_debug::_Safe_local_iterator< _Base_const_local_iterator, unordered_set > | 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_set > | iterator |
typedef _Base::key_equal | key_equal |
typedef _Base::key_type | key_type |
typedef __gnu_debug::_Safe_local_iterator< _Base_local_iterator, unordered_set > | local_iterator |
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_set (_Base_ref __x) | |
template<typename _InputIterator > | |
unordered_set (_InputIterator __first, _InputIterator __last, size_type __n, const allocator_type &__a) | |
template<typename _InputIterator > | |
unordered_set (_InputIterator __first, _InputIterator __last, size_type __n, const hasher &__hf, const allocator_type &__a) | |
template<typename _InputIterator > | |
unordered_set (_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_set (const allocator_type &__a) | |
unordered_set (const unordered_set &)=default | |
unordered_set (const unordered_set &__uset, const allocator_type &__a) | |
unordered_set (initializer_list< value_type > __l, size_type __n, const allocator_type &__a) | |
unordered_set (initializer_list< value_type > __l, size_type __n, const hasher &__hf, const allocator_type &__a) | |
unordered_set (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_set (size_type __n, const allocator_type &__a) | |
unordered_set (size_type __n, const hasher &__hf, const allocator_type &__a) | |
unordered_set (size_type __n, const hasher &__hf=hasher(), const key_equal &__eql=key_equal(), const allocator_type &__a=allocator_type()) | |
unordered_set (unordered_set &&)=default | |
unordered_set (unordered_set &&__uset, const allocator_type &__a) noexcept(noexcept(_Base(std::move(__uset), __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) |
std::pair< iterator, bool > | insert (const value_type &__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 &&__obj) |
insert_return_type | insert (node_type &&__nh) |
void | insert (std::initializer_list< value_type > __l) |
std::pair< iterator, bool > | insert (value_type &&__obj) |
float | max_load_factor () const noexcept |
void | max_load_factor (float __f) |
template<typename _H2 , typename _P2 > | |
void | merge (unordered_multiset< _Value, _H2, _P2, _Alloc > &&__source) |
template<typename _H2 , typename _P2 > | |
void | merge (unordered_multiset< _Value, _H2, _P2, _Alloc > &__source) |
template<typename _H2 , typename _P2 > | |
void | merge (unordered_set< _Value, _H2, _P2, _Alloc > &&__source) |
template<typename _H2 , typename _P2 > | |
void | merge (unordered_set< _Value, _H2, _P2, _Alloc > &__source) |
unordered_set & | operator= (const unordered_set &)=default |
unordered_set & | operator= (initializer_list< value_type > __l) |
unordered_set & | operator= (unordered_set &&)=default |
void | swap (unordered_set &__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_set with safety/checking/debug instrumentation.
Definition at line 60 of file debug/unordered_set.
typedef _Base::allocator_type std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::allocator_type |
Definition at line 94 of file debug/unordered_set.
typedef __gnu_debug::_Safe_iterator< _Base_const_iterator, unordered_set> std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::const_iterator |
Definition at line 106 of file debug/unordered_set.
typedef __gnu_debug::_Safe_local_iterator< _Base_const_local_iterator, unordered_set> std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::const_local_iterator |
Definition at line 110 of file debug/unordered_set.
typedef _Base::const_pointer std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::const_pointer |
Definition at line 100 of file debug/unordered_set.
typedef _Base::const_reference std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::const_reference |
Definition at line 102 of file debug/unordered_set.
typedef _Base::difference_type std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::difference_type |
Definition at line 91 of file debug/unordered_set.
typedef _Base::hasher std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::hasher |
Definition at line 92 of file debug/unordered_set.
using std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::insert_return_type = _Node_insert_return<iterator, node_type> |
Definition at line 412 of file debug/unordered_set.
typedef __gnu_debug::_Safe_iterator< _Base_iterator, unordered_set> std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::iterator |
Definition at line 104 of file debug/unordered_set.
typedef _Base::key_equal std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::key_equal |
Definition at line 93 of file debug/unordered_set.
typedef _Base::key_type std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::key_type |
Definition at line 96 of file debug/unordered_set.
typedef __gnu_debug::_Safe_local_iterator< _Base_local_iterator, unordered_set> std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::local_iterator |
Definition at line 108 of file debug/unordered_set.
using std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::node_type = typename _Base::node_type |
Definition at line 411 of file debug/unordered_set.
typedef _Base::pointer std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::pointer |
Definition at line 99 of file debug/unordered_set.
typedef _Base::reference std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::reference |
Definition at line 101 of file debug/unordered_set.
typedef _Base::size_type std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::size_type |
Definition at line 90 of file debug/unordered_set.
typedef _Base::value_type std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::value_type |
Definition at line 97 of file debug/unordered_set.
|
inlineexplicit |
Definition at line 115 of file debug/unordered_set.
|
inline |
Definition at line 122 of file debug/unordered_set.
|
inline |
Definition at line 134 of file debug/unordered_set.
|
inlineexplicit |
Definition at line 140 of file debug/unordered_set.
|
inline |
Definition at line 143 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 147 of file debug/unordered_set.
|
inline |
Definition at line 153 of file debug/unordered_set.
|
inline |
Definition at line 160 of file debug/unordered_set.
|
inline |
Definition at line 164 of file debug/unordered_set.
|
inline |
Definition at line 170 of file debug/unordered_set.
|
inline |
Definition at line 177 of file debug/unordered_set.
|
inline |
Definition at line 183 of file debug/unordered_set.
|
inline |
Definition at line 189 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 604 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 601 of file debug/unordered_set.
|
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 236 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 232 of file debug/unordered_set.
|
inline |
Definition at line 257 of file debug/unordered_set.
|
inline |
Definition at line 271 of file debug/unordered_set.
|
inline |
Definition at line 302 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 248 of file debug/unordered_set.
|
inline |
Definition at line 285 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 252 of file debug/unordered_set.
|
inline |
Definition at line 292 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 225 of file debug/unordered_set.
|
inline |
Definition at line 327 of file debug/unordered_set.
|
inline |
Definition at line 337 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 244 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 240 of file debug/unordered_set.
|
inline |
Definition at line 264 of file debug/unordered_set.
|
inline |
Definition at line 278 of file debug/unordered_set.
|
inline |
Definition at line 521 of file debug/unordered_set.
|
inline |
Definition at line 540 of file debug/unordered_set.
|
inline |
Definition at line 510 of file debug/unordered_set.
|
inline |
Definition at line 529 of file debug/unordered_set.
|
inline |
Definition at line 568 of file debug/unordered_set.
|
inline |
Definition at line 548 of file debug/unordered_set.
|
inline |
Definition at line 582 of file debug/unordered_set.
|
inline |
Definition at line 561 of file debug/unordered_set.
|
inline |
Definition at line 575 of file debug/unordered_set.
|
inline |
Definition at line 422 of file debug/unordered_set.
|
inline |
Definition at line 415 of file debug/unordered_set.
|
inline |
Definition at line 486 of file debug/unordered_set.
|
inline |
Definition at line 499 of file debug/unordered_set.
|
inline |
Definition at line 478 of file debug/unordered_set.
|
inline |
Definition at line 491 of file debug/unordered_set.
|
inline |
Definition at line 395 of file debug/unordered_set.
|
inline |
Definition at line 348 of file debug/unordered_set.
|
inline |
Definition at line 357 of file debug/unordered_set.
|
inline |
Definition at line 439 of file debug/unordered_set.
|
inline |
Definition at line 376 of file debug/unordered_set.
|
inline |
Definition at line 431 of file debug/unordered_set.
|
inline |
Definition at line 386 of file debug/unordered_set.
|
inline |
Definition at line 367 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 312 of file debug/unordered_set.
|
inline |
Definition at line 316 of file debug/unordered_set.
|
inline |
Definition at line 470 of file debug/unordered_set.
|
inline |
Definition at line 461 of file debug/unordered_set.
|
inline |
Definition at line 456 of file debug/unordered_set.
|
inline |
Definition at line 447 of file debug/unordered_set.
|
inline |
Definition at line 204 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 217 of file debug/unordered_set.
|
friend |
Definition at line 77 of file debug/unordered_set.
|
friend |
Definition at line 79 of file debug/unordered_set.
|
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().