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::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::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._M_base()), __a))) | |
const _Base & | _M_base () const noexcept |
_Base & | _M_base () noexcept |
void | _M_swap (_Safe_container &__x) noexcept |
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 |
std::pair< iterator, iterator > | equal_range (const key_type &__key) |
std::pair< const_iterator, const_iterator > | equal_range (const key_type &__key) const |
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) |
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) |
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 () |
void | _M_invalidate_all () const |
void | _M_invalidate_if (_Predicate __pred) |
void | _M_invalidate_local_if (_Predicate __pred) |
void | _M_invalidate_locals () |
void | _M_revalidate_singular () |
_Safe_container & | _M_safe () noexcept |
void | _M_swap (_Safe_sequence_base &__x) noexcept |
void | _M_swap (_Safe_unordered_container_base &__x) noexcept |
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 93 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 101 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 105 of file debug/unordered_set.
typedef _Base::hasher std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::hasher |
Definition at line 91 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 393 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 99 of file debug/unordered_set.
typedef _Base::key_equal std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::key_equal |
Definition at line 92 of file debug/unordered_set.
typedef _Base::key_type std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::key_type |
Definition at line 95 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 103 of file debug/unordered_set.
using std::__debug::unordered_set< _Value, _Hash, _Pred, _Alloc >::node_type = typename _Base::node_type |
Definition at line 392 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 96 of file debug/unordered_set.
|
inlineexplicit |
Definition at line 110 of file debug/unordered_set.
|
inline |
Definition at line 117 of file debug/unordered_set.
|
inline |
Definition at line 129 of file debug/unordered_set.
|
inlineexplicit |
Definition at line 135 of file debug/unordered_set.
|
inline |
Definition at line 138 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 142 of file debug/unordered_set.
|
inline |
Definition at line 148 of file debug/unordered_set.
|
inline |
Definition at line 155 of file debug/unordered_set.
|
inline |
Definition at line 159 of file debug/unordered_set.
|
inline |
Definition at line 165 of file debug/unordered_set.
|
inline |
Definition at line 172 of file debug/unordered_set.
|
inline |
Definition at line 178 of file debug/unordered_set.
|
inline |
Definition at line 184 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 543 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 540 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().
|
inlineprotectedinherited |
Definition at line 76 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.
|
protectedinherited |
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 90 of file safe_unordered_container.tcc.
|
protectedinherited |
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 98 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 52 of file safe_container.h.
|
inlinenoexceptinherited |
Definition at line 111 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.
|
inlinenoexcept |
Definition at line 226 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 222 of file debug/unordered_set.
|
inline |
Definition at line 247 of file debug/unordered_set.
|
inline |
Definition at line 261 of file debug/unordered_set.
|
inline |
Definition at line 289 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 238 of file debug/unordered_set.
|
inline |
Definition at line 275 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 242 of file debug/unordered_set.
|
inline |
Definition at line 282 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 215 of file debug/unordered_set.
|
inline |
Definition at line 308 of file debug/unordered_set.
|
inline |
Definition at line 318 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 234 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 230 of file debug/unordered_set.
|
inline |
Definition at line 254 of file debug/unordered_set.
|
inline |
Definition at line 268 of file debug/unordered_set.
|
inline |
Definition at line 456 of file debug/unordered_set.
|
inline |
Definition at line 475 of file debug/unordered_set.
|
inline |
Definition at line 494 of file debug/unordered_set.
|
inline |
Definition at line 521 of file debug/unordered_set.
|
inline |
Definition at line 507 of file debug/unordered_set.
|
inline |
Definition at line 514 of file debug/unordered_set.
|
inline |
Definition at line 403 of file debug/unordered_set.
|
inline |
Definition at line 396 of file debug/unordered_set.
|
inline |
Definition at line 430 of file debug/unordered_set.
|
inline |
Definition at line 443 of file debug/unordered_set.
|
inline |
Definition at line 376 of file debug/unordered_set.
|
inline |
Definition at line 329 of file debug/unordered_set.
|
inline |
Definition at line 338 of file debug/unordered_set.
|
inline |
Definition at line 420 of file debug/unordered_set.
|
inline |
Definition at line 357 of file debug/unordered_set.
|
inline |
Definition at line 412 of file debug/unordered_set.
|
inline |
Definition at line 367 of file debug/unordered_set.
|
inline |
Definition at line 348 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 296 of file debug/unordered_set.
|
inline |
Definition at line 300 of file debug/unordered_set.
|
inline |
Definition at line 199 of file debug/unordered_set.
|
inlinenoexcept |
Definition at line 207 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().