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 );
| (since C++20) |
Assigns the underlying std::variant member object var from that of x.
Let i is x.var.index(). Then, this assignment is equivalent to:
std::get<i>(var) = std::get<i>(x.var), if var.index() == i, var.emplace<i>(std::get<i>(x.var)) otherwise. The behavior is undefined if x is in an invalid state, that is, x.var.valueless_by_exception() is equal to true.
| x | - | iterator adaptor to assign from |
*this.
#include <algorithm>
#include <iostream>
#include <iterator>
#include <initializer_list>
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';
}Output:
2 3 4 5 6 3 4 5 6
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 3574 | C++20 | variant was fully constexpr (P2231R1) but common_iterator was not | also made constexpr |
|
(C++20) | constructs a new iterator adaptor (public member function) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/iterator/common_iterator/operator%3D