Namespaces
Variants

std:: make_reverse_iterator

From cppreference.net
Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
(C++11) (C++14)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
Definiert im Header <iterator>
template < class Iter >
std:: reverse_iterator < Iter > make_reverse_iterator ( Iter i ) ;
(seit C++14)
(constexpr seit C++17)

make_reverse_iterator ist eine praktische Funktionsvorlage, die einen std::reverse_iterator für den gegebenen Iterator i konstruiert (welcher ein LegacyBidirectionalIterator sein muss), wobei der Typ vom Typ des Arguments abgeleitet wird.

Inhaltsverzeichnis

Parameter

i - Iterator, der in einen Reverse-Iterator umgewandelt werden soll

Rückgabewert

std:: reverse_iterator < Iter > ( i )

Hinweise

Feature-Test Makro Wert Std Feature
__cpp_lib_make_reverse_iterator 201402L (C++14) std::make_reverse_iterator

Beispiel

#include <algorithm>
#include <iostream>
#include <iterator>
#include <vector>
int main()
{
    std::vector<int> v{1, 3, 10, 8, 22};
    std::sort(v.begin(), v.end());
    std::copy(v.begin(), v.end(), std::ostream_iterator<int>(std::cout, ", "));
    std::cout << '\n';
    std::copy(std::make_reverse_iterator(v.end()),
              std::make_reverse_iterator(v.begin()),
              std::ostream_iterator<int>(std::cout, ", "));
    std::cout << '\n';
}

Ausgabe:

1, 3, 8, 10, 22,
22, 10, 8, 3, 1,

Siehe auch

Iterator-Adapter für die Traversierung in umgekehrter Reihenfolge
(Klassen-Template)
gibt einen Reverse-Iterator zum Anfang eines Containers oder Arrays zurück
(Funktions-Template)
(C++14)
gibt einen Reverse-End-Iterator für einen Container oder ein Array zurück
(Funktions-Template)