Invariants
Ordering |
Two different iterations through a forward container will access its elements in the same order, providing that there have been no intervening mutative operations. |
Models
• vector
• list
• slist
• deque
• set
• hash_set
• map
• hash_map
• multiset
• hash_multiset
• multimap
• hash_multimap
See also
The iterator overview, Forward Iterator, Sequence
Category: containers
Component type: concept
Description
A Reversible Container is a Forward Container whose iterators are Bidirectional Iterators. It allows backwards iteration through the container.
Refinement of
Forward Container
Associated types
Two new types are introduced. In addition, the iterator type and the const iterator type must satisfy a more stringent requirement than for a Forward Container. The iterator and reverse iterator types must be Bidirectional Iterators, not merely Forward Iterators.
Reverse iterator type |
X::reverse_iterator |
A Reverse Iterator adaptor whose base iterator type is the container's iterator type. Incrementing an object of type reverse_iterator moves backwards through the container: the Reverse Iterator adaptor maps operator++ to operator-- . |
Const reverse iterator type |
X::const_reverse_iterator |
A Reverse Iterator adaptor whose base iterator type is the container's const iterator type. [1] |
Notation
X
A type that is a model of Reversible Container
a, b
Object of type X
Valid expressions
In addition to the expressions defined in Forward Container, the following expressions must be valid.
Name |
Expression |
Return type |
Beginning of range |
a.rbegin() |
reverse_iterator if a is mutable, const_reverse_iterator otherwise [1] |
End of range |
a.rend() |
reverse_iterator if a is mutable, const_reverse_iterator otherwise [1] |
Expression semantics
Semantics of an expression is defined only where it is not defined in Forward Container, or where there is additional information.
Name |
Expression |
Semantics |
Postcondition |
Beginning of reverse range |
a.rbegin() |
Equivalent to X::reverse_iterator(a.end()). |
a.rbegin() is dereferenceable or past-the-end. It is past-the-end if and only if a.size() == 0 . |
End of reverse range |
a.rend() |
Equivalent to X::reverse_iterator(a.begin()). |
a.end() is past-the-end. |
Complexity guarantees
The run-time complexity of rbegin() and rend() is amortized constant time.
Invariants
Valid range |
[a.rbegin(), a.rend()) is a valid range. |
Equivalence of ranges |
The distance from a.begin() to a.end() is the same as the distance from a.rbegin() to a.rend() . |
Models
• vector
• list
• deque
Notes
[1] A Container's iterator type and const iterator type may be the same type: a container need not provide mutable iterators. It follows from this that the reverse iterator type and the const reverse iterator type may also be the same.
See also
The Iterator overview, Bidirectional Iterator, Sequence
Category: containers
Component type: concept
Description
A Random Access Container is a Reversible Container whose iterator type is a Random Access Iterator. It provides amortized constant time access to arbitrary elements.
Refinement of
Reversible Container
Associated types
No additional types beyond those defined in Reversible Container. However, the requirements for the iterator type are strengthened: it must be a Random Access Iterator.
Notation
X
A type that is a model of Random Access Container
a, b
Object of type X
T
The value type of X
Valid expressions
In addition to the expressions defined in Reversible Container, the following expressions must be valid.
Name |
Expression |
Type requirements |
Return type |
Element access |
a[n] |
n is convertible to size_type |
reference if a is mutable, const_reference otherwise |
Expression semantics
Semantics of an expression is defined only where it is not defined in Reversible Container, or where there is additional information.
Name |
Expression |
Precondition |
Semantics |
Element access |
a[n] |
0 <= n < a.size() |
Returns the n th element from the beginning of the container. |
Complexity guarantees
The run-time complexity of element access is amortized constant time.
Invariants
Element access |
The element returned by a[n] is the same as the one obtained by incrementing a.begin()n times and then dereferencing the resulting iterator. |
Models
• vector
• deque
See also
The Iterator overview, Random Access Iterator, Sequence
Category: containers
Component type: concept
Description
A Sequence is a variable-sized Container whose elements are arranged in a strict linear order. It supports insertion and removal of elements.
Refinement of
Forward Container, Default Constructible
Associated types
None, except for those of Forward Container.
Notation
X
A type that is a model of Sequence
a, b
Object of type X
T
The value type of X
t
Object of type T
p, q
Object of type X::iterator
n
Object of a type convertible to X::size_type
Definitions
If a is a Sequence, then p is a valid iterator in a if it is a valid (nonsingular) iterator that is reachable from a.begin() .
If a is a Sequence, then [p, q) is a valid range in a if p and q are valid iterators in a and if q is reachable from p .
Valid expressions
In addition to the expressions defined in Forward Container, the following expressions must be valid.
Читать дальше