operator+ (std::reverse_iterator)
| Iterator concepts | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Iterator primitives | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Algorithm concepts and utilities | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Indirect callable concepts | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Common algorithm requirements | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Utilities | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Iterator adaptors | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Member functions | ||||
| Non-member functions | ||||
|
operator+
|
||||
|
(C++20)
|
||||
|
(C++20)
|
||||
|
(C++14)
|
|
Défini dans l'en-tête
<iterator>
|
||
|
template
<
class
Iter
>
reverse_iterator
<
Iter
>
operator
+
|
(constexpr depuis C++17)
(jusqu'à C++23) |
|
|
template
<
class
Iter
>
constexpr
reverse_iterator
<
Iter
>
operator
+
|
(depuis C++23) | |
Renvoie l'itérateur it incrémenté de n . En réalité, l'itérateur sous-jacent est décrémenté de n .
Table des matières |
Paramètres
| n | - | le nombre de positions pour incrémenter l'itérateur |
| it | - | l'adaptateur d'itérateur à incrémenter |
Valeur de retour
reverse_iterator < Iter > ( it. base ( ) - n )
Exemple
#include <iostream> #include <iterator> #include <list> #include <vector> int main() { { std::vector v{0, 1, 2, 3}; std::reverse_iterator<std::vector<int>::iterator> ri1{std::reverse_iterator{v.rbegin()}}; std::cout << *ri1 << ' '; // 3 std::reverse_iterator<std::vector<int>::iterator> ri2{2 + ri1}; std::cout << *ri2 << ' '; // 1 } { std::list l{5, 6, 7, 8}; std::reverse_iterator<std::list<int>::iterator> ri1{std::reverse_iterator{l.rbegin()}}; std::cout << *ri1 << '\n'; // 8 // auto ri2{2 + ri1}; // Erreur : l'itérateur sous-jacent n'implémente pas // le concept d'itérateur à accès aléatoire } }
Sortie :
3 1 8
Voir aussi
avance ou décrémente le
reverse_iterator
(fonction membre publique) |
|
|
calcule la distance entre deux adaptateurs d'itérateur
(fonction template) |