Namespaces
Variants

std::common_iterator<I,S>:: common_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)
constexpr common_iterator ( ) requires std:: default_initializable < I > = default ;
(1) (depuis C++20)
constexpr common_iterator ( I i ) ;
(2) (depuis C++20)
constexpr common_iterator ( S s ) ;
(3) (depuis C++20)
template < class I2, class S2 >

requires std:: convertible_to < const I2 & , I > &&
std:: convertible_to < const S2 & , S >

constexpr common_iterator ( const common_iterator < I2, S2 > & x ) ;
(4) (depuis C++20)

Construit un nouvel adaptateur d'itérateur, initialise effectivement l'objet membre sous-jacent std:: variant < I, S > pour contenir un objet var de type I (itérateur) ou S (sentinelle).

1) Constructeur par défaut. Initialise par défaut var . Après construction, var contient un objet I initialisé par valeur. Les opérations sur l'adaptateur d'itérateur résultant ont un comportement défini si et seulement si les opérations correspondantes sur un I initialisé par valeur ont également un comportement défini.
2) Après construction, var contient un objet I construit par déplacement à partir de i .
3) Après construction, var contient un objet S construit par déplacement à partir de s .
4) Après la construction, var contient un objet I ou S initialisé à partir de l'objet I2 ou S2 contenu par x. var , si x. var contient cette alternative, respectivement. Le comportement est indéfini si x est dans un état invalide, c'est-à-dire si x. var . valueless_by_exception ( ) est égal à true .

Paramètres

i - itérateur à adapter
s - sentinelle à adapter
x - adaptateur d'itérateur à copier

Exemple

#include <algorithm>
#include <iostream>
#include <iterator>
#include <numeric>
#include <vector>
int main()
{
    std::vector v{3, 1, 4, 1, 5, 9, 2};
    using CI = std::common_iterator<
                   std::counted_iterator<std::vector<int>::iterator>,
                   std::default_sentinel_t>;
    CI unused; // (1)
    CI start{std::counted_iterator{std::next(begin(v)), ssize(v) - 2}}; // (2)
    CI finish{std::default_sentinel}; // (3)
    CI first{start}; // (4)
    CI last{finish}; // (4)
    std::copy(first, last, std::ostream_iterator<int>{std::cout, " "});
    std::cout << '\n';
    std::common_iterator<
        std::counted_iterator<
            std::ostream_iterator<double>>,
            std::default_sentinel_t>
            beg{std::counted_iterator{std::ostream_iterator<double>{std::cout,";  "}, 5}},
            end{std::default_sentinel};
    std::iota(beg, end, 3.1);
    std::cout << '\n';
}

Sortie :

1 4 1 5 9
3.1;  4.1;  5.1;  6.1;  7.1;

Voir aussi

assigne un autre common_iterator
(fonction membre publique)