libstdc++
|
#include <map.h>
Public Types | |
typedef _Allocator | allocator_type |
typedef __gnu_debug::_Safe_iterator< _Base_const_iterator, map > | const_iterator |
typedef _Base::const_pointer | const_pointer |
typedef _Base::const_reference | const_reference |
typedef std::reverse_iterator< const_iterator > | const_reverse_iterator |
typedef _Base::difference_type | difference_type |
typedef __gnu_debug::_Safe_iterator< _Base_iterator, map > | iterator |
typedef _Compare | key_compare |
typedef _Key | key_type |
typedef _Tp | mapped_type |
typedef _Base::pointer | pointer |
typedef _Base::reference | reference |
typedef std::reverse_iterator< iterator > | reverse_iterator |
typedef _Base::size_type | size_type |
typedef std::pair< const _Key, _Tp > | value_type |
Public Member Functions | |
template<typename _InputIterator > | |
map (_InputIterator __first, _InputIterator __last, const _Compare &__comp=_Compare(), const _Allocator &__a=_Allocator()) | |
template<typename _InputIterator > | |
map (_InputIterator __first, _InputIterator __last, const allocator_type &__a) | |
map (const _Base &__x) | |
map (const _Compare &__comp, const _Allocator &__a=_Allocator()) | |
map (const allocator_type &__a) | |
map (const map &)=default | |
map (const map &__m, const allocator_type &__a) | |
map (initializer_list< value_type > __l, const _Compare &__c=_Compare(), const allocator_type &__a=allocator_type()) | |
map (initializer_list< value_type > __l, const allocator_type &__a) | |
map (map &&)=default | |
map (map &&__m, const allocator_type &__a) noexcept(noexcept(_Base(std::move(__m._M_base()), __a))) | |
const _Base & | _M_base () const noexcept |
_Base & | _M_base () noexcept |
void | _M_invalidate_if (_Predicate __pred) |
void | _M_swap (_Safe_container &__x) noexcept |
void | _M_transfer_from_if (_Safe_sequence &__from, _Predicate __pred) |
const_iterator | begin () const noexcept |
iterator | begin () noexcept |
const_iterator | cbegin () const noexcept |
const_iterator | cend () const noexcept |
void | clear () noexcept |
const_reverse_iterator | crbegin () const noexcept |
const_reverse_iterator | crend () const noexcept |
template<typename... _Args> | |
std::pair< iterator, bool > | emplace (_Args &&... __args) |
template<typename... _Args> | |
iterator | emplace_hint (const_iterator __pos, _Args &&... __args) |
const_iterator | end () const noexcept |
iterator | end () noexcept |
template<typename _Kt , typename _Req = typename __has_is_transparent<_Compare, _Kt>::type> | |
std::pair< iterator, iterator > | equal_range (const _Kt &__x) |
template<typename _Kt , typename _Req = typename __has_is_transparent<_Compare, _Kt>::type> | |
std::pair< const_iterator, const_iterator > | equal_range (const _Kt &__x) const |
std::pair< iterator, iterator > | equal_range (const key_type &__x) |
std::pair< const_iterator, const_iterator > | equal_range (const key_type &__x) const |
size_type | erase (const key_type &__x) |
iterator | erase (const_iterator __first, const_iterator __last) |
iterator | erase (const_iterator __position) |
_GLIBCXX_ABI_TAG_CXX11 iterator | erase (iterator __position) |
template<typename _Kt , typename _Req = typename __has_is_transparent<_Compare, _Kt>::type> | |
iterator | find (const _Kt &__x) |
template<typename _Kt , typename _Req = typename __has_is_transparent<_Compare, _Kt>::type> | |
const_iterator | find (const _Kt &__x) const |
iterator | find (const key_type &__x) |
const_iterator | find (const key_type &__x) 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 &&__x) |
std::pair< iterator, bool > | insert (const value_type &__x) |
template<typename _Pair , typename = typename std::enable_if<std::is_constructible<value_type, _Pair&&>::value>::type> | |
iterator | insert (const_iterator __position, _Pair &&__x) |
iterator | insert (const_iterator __position, const value_type &__x) |
iterator | insert (const_iterator __position, value_type &&__x) |
void | insert (std::initializer_list< value_type > __list) |
std::pair< iterator, bool > | insert (value_type &&__x) |
template<typename _Kt , typename _Req = typename __has_is_transparent<_Compare, _Kt>::type> | |
iterator | lower_bound (const _Kt &__x) |
template<typename _Kt , typename _Req = typename __has_is_transparent<_Compare, _Kt>::type> | |
const_iterator | lower_bound (const _Kt &__x) const |
iterator | lower_bound (const key_type &__x) |
const_iterator | lower_bound (const key_type &__x) const |
map & | operator= (const map &)=default |
map & | operator= (initializer_list< value_type > __l) |
map & | operator= (map &&)=default |
const_reverse_iterator | rbegin () const noexcept |
reverse_iterator | rbegin () noexcept |
const_reverse_iterator | rend () const noexcept |
reverse_iterator | rend () noexcept |
void | swap (map &__x) noexcept(/*conditional */) |
template<typename _Kt , typename _Req = typename __has_is_transparent<_Compare, _Kt>::type> | |
iterator | upper_bound (const _Kt &__x) |
template<typename _Kt , typename _Req = typename __has_is_transparent<_Compare, _Kt>::type> | |
const_iterator | upper_bound (const _Kt &__x) const |
iterator | upper_bound (const key_type &__x) |
const_iterator | upper_bound (const key_type &__x) const |
Public Attributes | |
_Safe_iterator_base * | _M_const_iterators |
_Safe_iterator_base * | _M_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_revalidate_singular () |
_Safe_container & | _M_safe () noexcept |
void | _M_swap (_Safe_sequence_base &__x) noexcept |
Friends | |
template<typename _ItT , typename _SeqT , typename _CatT > | |
class | ::__gnu_debug::_Safe_iterator |
Class std::map with safety/checking/debug instrumentation.
Definition at line 44 of file debug/map.h.
typedef _Allocator std::__debug::map< _Key, _Tp, _Compare, _Allocator >::allocator_type |
Definition at line 68 of file debug/map.h.
typedef __gnu_debug::_Safe_iterator<_Base_const_iterator, map> std::__debug::map< _Key, _Tp, _Compare, _Allocator >::const_iterator |
Definition at line 75 of file debug/map.h.
typedef _Base::const_pointer std::__debug::map< _Key, _Tp, _Compare, _Allocator >::const_pointer |
Definition at line 80 of file debug/map.h.
typedef _Base::const_reference std::__debug::map< _Key, _Tp, _Compare, _Allocator >::const_reference |
Definition at line 70 of file debug/map.h.
typedef std::reverse_iterator<const_iterator> std::__debug::map< _Key, _Tp, _Compare, _Allocator >::const_reverse_iterator |
Definition at line 82 of file debug/map.h.
typedef _Base::difference_type std::__debug::map< _Key, _Tp, _Compare, _Allocator >::difference_type |
Definition at line 78 of file debug/map.h.
typedef __gnu_debug::_Safe_iterator<_Base_iterator, map> std::__debug::map< _Key, _Tp, _Compare, _Allocator >::iterator |
Definition at line 73 of file debug/map.h.
typedef _Compare std::__debug::map< _Key, _Tp, _Compare, _Allocator >::key_compare |
Definition at line 67 of file debug/map.h.
typedef _Key std::__debug::map< _Key, _Tp, _Compare, _Allocator >::key_type |
Definition at line 64 of file debug/map.h.
typedef _Tp std::__debug::map< _Key, _Tp, _Compare, _Allocator >::mapped_type |
Definition at line 65 of file debug/map.h.
typedef _Base::pointer std::__debug::map< _Key, _Tp, _Compare, _Allocator >::pointer |
Definition at line 79 of file debug/map.h.
typedef _Base::reference std::__debug::map< _Key, _Tp, _Compare, _Allocator >::reference |
Definition at line 69 of file debug/map.h.
typedef std::reverse_iterator<iterator> std::__debug::map< _Key, _Tp, _Compare, _Allocator >::reverse_iterator |
Definition at line 81 of file debug/map.h.
typedef _Base::size_type std::__debug::map< _Key, _Tp, _Compare, _Allocator >::size_type |
Definition at line 77 of file debug/map.h.
typedef std::pair<const _Key, _Tp> std::__debug::map< _Key, _Tp, _Compare, _Allocator >::value_type |
Definition at line 66 of file debug/map.h.
|
inline |
Definition at line 98 of file debug/map.h.
|
inlineexplicit |
Definition at line 104 of file debug/map.h.
|
inline |
Definition at line 107 of file debug/map.h.
|
inlinenoexcept |
Definition at line 110 of file debug/map.h.
|
inline |
Definition at line 115 of file debug/map.h.
|
inline |
Definition at line 119 of file debug/map.h.
|
inline |
Definition at line 129 of file debug/map.h.
|
inlineexplicit |
Definition at line 132 of file debug/map.h.
|
inline |
Definition at line 137 of file debug/map.h.
|
inlinenoexcept |
Definition at line 698 of file debug/map.h.
|
inlinenoexcept |
Definition at line 695 of file debug/map.h.
|
protectedinherited |
Detach all iterators, leaving them singular.
Referenced by __gnu_debug::_Safe_sequence_base::~_Safe_sequence_base().
|
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 136 of file safe_sequence.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 sequence, 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 117 of file safe_sequence.tcc.
|
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 104 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.
|
inherited |
Transfers all iterators x
that reference from
sequence, 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 125 of file safe_sequence.tcc.
|
inlinenoexcept |
Definition at line 179 of file debug/map.h.
|
inlinenoexcept |
Definition at line 175 of file debug/map.h.
|
inlinenoexcept |
Definition at line 208 of file debug/map.h.
|
inlinenoexcept |
Definition at line 212 of file debug/map.h.
|
inlinenoexcept |
Definition at line 561 of file debug/map.h.
|
inlinenoexcept |
Definition at line 216 of file debug/map.h.
|
inlinenoexcept |
Definition at line 220 of file debug/map.h.
|
inline |
Definition at line 240 of file debug/map.h.
|
inline |
Definition at line 248 of file debug/map.h.
|
inlinenoexcept |
Definition at line 187 of file debug/map.h.
|
inlinenoexcept |
Definition at line 183 of file debug/map.h.
|
inline |
Definition at line 666 of file debug/map.h.
|
inline |
Definition at line 687 of file debug/map.h.
|
inline |
Definition at line 653 of file debug/map.h.
|
inline |
Definition at line 674 of file debug/map.h.
|
inline |
Definition at line 500 of file debug/map.h.
|
inline |
Definition at line 515 of file debug/map.h.
|
inline |
Definition at line 478 of file debug/map.h.
|
inline |
Definition at line 487 of file debug/map.h.
|
inline |
Definition at line 581 of file debug/map.h.
|
inline |
Definition at line 594 of file debug/map.h.
|
inline |
Definition at line 573 of file debug/map.h.
|
inline |
Definition at line 586 of file debug/map.h.
|
inline |
Definition at line 332 of file debug/map.h.
|
inline |
Definition at line 281 of file debug/map.h.
|
inline |
Definition at line 260 of file debug/map.h.
|
inline |
Definition at line 319 of file debug/map.h.
|
inline |
Definition at line 296 of file debug/map.h.
|
inline |
Definition at line 309 of file debug/map.h.
|
inline |
Definition at line 290 of file debug/map.h.
|
inline |
Definition at line 271 of file debug/map.h.
|
inline |
Definition at line 609 of file debug/map.h.
|
inline |
Definition at line 622 of file debug/map.h.
|
inline |
Definition at line 601 of file debug/map.h.
|
inline |
Definition at line 614 of file debug/map.h.
|
inline |
Definition at line 161 of file debug/map.h.
|
inlinenoexcept |
Definition at line 195 of file debug/map.h.
|
inlinenoexcept |
Definition at line 191 of file debug/map.h.
|
inlinenoexcept |
Definition at line 203 of file debug/map.h.
|
inlinenoexcept |
Definition at line 199 of file debug/map.h.
|
inlinenoexcept |
Definition at line 553 of file debug/map.h.
|
inline |
Definition at line 635 of file debug/map.h.
|
inline |
Definition at line 648 of file debug/map.h.
|
inline |
Definition at line 627 of file debug/map.h.
|
inline |
Definition at line 640 of file debug/map.h.
|
friend |
Definition at line 60 of file debug/map.h.
|
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 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().
|
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().