Namespaces
Variants

std::move_iterator<Iter>:: base

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)
(1)
iterator_type base ( ) const ;
(constexpr seit C++17)
(bis C++20)
constexpr const iterator_type & base ( ) const & noexcept ;
(seit C++20)
constexpr iterator_type base ( ) && ;
(2) (seit C++20)

Gibt den zugrunde liegenden Iterator zurück.

1) Gibt eine Kopie des (bis C++20) Referenz auf den (seit C++20) zugrundeliegenden Iterators zurück.
2) Gibt einen Iterator zurück, der durch Move-Konstruktion aus dem zugrunde liegenden Iterator erstellt wurde.

Inhaltsverzeichnis

Rückgabewert

2) std :: move ( current  )

Beispiel

#include <algorithm>
#include <iostream>
#include <iterator>
#include <vector>
int main()
{
    std::vector<int> v{0, 1, 2, 3, 4};
    std::move_iterator<std::vector<int>::reverse_iterator>
        m1{v.rbegin()},
        m2{v.rend()};
    std::copy(m1.base(), m2.base(), std::ostream_iterator<int>(std::cout, " "));
    std::cout << '\n';
}

Ausgabe:

4 3 2 1 0

Fehlerberichte

Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR Angewendet auf Verhalten wie veröffentlicht Korrektes Verhalten
LWG 3391 C++20 Überladung ( 1 ) gab eine Kopie des zugrundeliegenden Iterators zurück gibt eine Referenz zurück
LWG 3593 C++20 Überladung ( 1 ) war nicht noexcept als noexcept festgelegt

Siehe auch

greift auf das referenzierte Element zu
(öffentliche Elementfunktion)