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) (C++20 起)
constexpr common_iterator ( I i ) ;
(2) (C++20 起)
constexpr common_iterator ( S s ) ;
(3) (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) (C++20 起)

构造一个新的迭代器适配器,实际上是将底层的 std:: variant < I, S > 成员对象 var 初始化为持有 I (迭代器)或 S (哨兵)对象。

1) 默认构造函数。默认初始化 var 。构造完成后, var 持有一个值初始化的 I 对象。 当且仅当对值初始化的 I 的相应操作具有定义行为时,对结果迭代器适配器的操作才具有定义行为。
2) 构造完成后, var 持有一个从 i 移动构造而来的 I 对象。
3) 构造完成后, var 持有一个从 s 移动构造而来的 S 对象。
4) 构造完成后,若 x. var 持有对应变体类型,则 var 将持有从 x. var 持有的 I2 S2 初始化的 I S 对象。若 x 处于无效状态(即 x. var . valueless_by_exception ( ) 等于 true ),则行为未定义。

参数

i - 待适配的迭代器
s - 待适配的哨位
x - 待复制的迭代器适配器

示例

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

输出:

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

参见

赋值另一个 common_iterator
(公开成员函数)