命名空间
变体
操作

operator-(std::common_iterator)

来自 cppreference.cn
 
 
迭代器库
迭代器概念
迭代器原语
算法概念与工具
间接可调用概念
常用算法要求
工具
迭代器适配器
 
 
template< std::sized_sentinel_for<I> I2, std::sized_sentinel_for<I> S2 >

    requires std::sized_sentinel_for<S, I2>
friend constexpr std::iter_difference_t<I2>

    operator-( const common_iterator& x, const std::common_iterator<I2, S2>& y );
(C++20 起)

计算两个迭代器适配器之间的距离。两个哨兵被认为是相等的。

var 表示 std::common_iterator 中底层的 std::variant 成员对象,如果 xy 无效,即 x.var.valueless_by_exception() || y.var.valueless_by_exception()true,则行为未定义。

此函数模板对普通的非限定限定查找不可见,只能通过实参依赖查找在 std::common_iterator<I> 是实参的关联类时被找到。

目录

[编辑] 参数

x, y - 要计算差异的迭代器适配器

[编辑] 返回值

  • 0 如果 x.var 持有一个 S 对象且 y.var 持有一个 S2 对象,即它们都持有一个哨兵。
  • 否则,为 alt_x - alt_y,其中 alt_xalt_y 分别是 x.vary.var 所持有的备选项(要么是两个迭代器,要么是一个迭代器和一个哨兵)。

[编辑] 示例

#include <algorithm>
#include <iostream>
#include <iterator>
 
int main()
{
    int a[]{0, 1, 2, 3, 4, 5};
 
    using CI = std::common_iterator<
                   std::counted_iterator<int*>,
                   std::default_sentinel_t
                   >;
 
    CI i1{std::counted_iterator{a + 1, 2}};
    CI i2{std::counted_iterator{a, 3}};
    CI s1{std::default_sentinel};
    CI s2{std::default_sentinel};
 
    std::cout << (s2 - s1) << ' '
              << (i2 - i1) << ' '
              << (i1 - s1) << '\n';
}

输出

0 -1 -2

[编辑] 缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 发布时的行为 正确的行为
LWG 3574 C++20 variant 完全为 constexpr (P2231R1) 但 common_iterator 不是 也设为 constexpr

[编辑] 参阅

前进 common_iterator
(公共成员函数) [编辑]