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 ) ;
(desde C++20)

Asigna el objeto miembro subyacente std::variant var a partir del de x .

Sea i el x. var . index ( ) . Entonces, esta asignación es equivalente a:

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

El comportamiento es indefinido si x está en un estado inválido, es decir, x. var . valueless_by_exception ( ) es igual a true .

Contenidos

Parámetros

x - adaptador de iterador para asignar desde

Valor de retorno

* this

Ejemplo

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

Salida:

2 3 4 5 6 
3 4 5 6

Informes de defectos

Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares de C++ publicados anteriormente.

DR Aplicado a Comportamiento publicado Comportamiento correcto
LWG 3574 C++20 variant era completamente constexpr (P2231R1) pero common_iterator no lo era también hecho constexpr

Véase también

construye un nuevo common_iterator
(función miembro pública)