Namespaces
Variants

std::common_iterator<I,S>:: operator=

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)
template < class I2, class S2 >

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

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

Assigne l'objet membre sous-jacent std::variant var à partir de celui de x .

Soit i est x. var . index ( ) . Alors, cette affectation est équivalente à :

  • std :: get < i > ( var ) = std :: get < i > ( x. var ) , si var. index ( ) == i ,
  • var. emplace < i > ( std :: get < i > ( x. var ) ) sinon.

Le comportement est indéfini si x est dans un état invalide, c'est-à-dire si x. var . valueless_by_exception ( ) est égal à true .

Table des matières

Paramètres

x - adaptateur d'itérateur pour assigner depuis

Valeur de retour

* this

Exemple

#include <algorithm>
#include <initializer_list>
#include <iostream>
#include <iterator>
int main()
{
    const auto il = {1, 2, 3, 4, 5, 6};
    using CI = std::common_iterator<
                   std::counted_iterator<std::initializer_list<int>::iterator>,
                   std::default_sentinel_t>;
    CI first{std::counted_iterator{std::next(begin(il), 1), ssize(il) - 1}};
    const CI first2{std::counted_iterator{std::next(begin(il), 2), ssize(il) - 2}};
    const CI last{std::default_sentinel};
    std::copy(first, last, std::ostream_iterator<int>{std::cout, " "});
    std::cout << '\n';
    first = first2;
    std::copy(first, last, std::ostream_iterator<int>{std::cout, " "});
    std::cout << '\n';
}

Sortie :

2 3 4 5 6 
3 4 5 6

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 S'applique à Comportement publié Comportement corrigé
LWG 3574 C++20 variant était entièrement constexpr (P2231R1) mais common_iterator ne l'était pas également rendu constexpr

Voir aussi

construit un nouveau common_iterator
(fonction membre publique)