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 depuis C++17)
(jusqu'à C++20)
constexpr const iterator_type & base ( ) const & noexcept ;
(depuis C++20)
constexpr iterator_type base ( ) && ;
(2) (depuis C++20)

Retourne l'itérateur sous-jacent.

1) Retourne une copie de (jusqu'au C++20) référence vers (depuis C++20) l'itérateur sous-jacent.
2) Retourne un itérateur construit par déplacement à partir de l'itérateur sous-jacent.

Table des matières

Valeur de retour

2) std :: move ( current  )

Exemple

#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';
}

Sortie :

4 3 2 1 0

Rapports de défauts

Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.

DR Applicable à Comportement publié Comportement corrigé
LWG 3391 C++20 la surcharge ( 1 ) renvoyait une copie de l'itérateur sous-jacent renvoie une référence
LWG 3593 C++20 la surcharge ( 1 ) n'était pas noexcept rendue noexcept

Voir aussi

accède à l'élément pointé
(fonction membre publique)