std::incrementable

来自cppreference.com
< cpp‎ | iterator
 
 
迭代器库
迭代器概念
(C++20)
(C++20)
incrementable
(C++20)
迭代器原语
迭代器适配器
流迭代器
迭代器定制点
迭代器操作
(C++11)
(C++11)
范围访问
(C++11)(C++14)
(C++11)(C++14)
(C++17)(C++20)
(C++14)(C++14)
(C++14)(C++14)
(C++17)
(C++17)
 
定义于头文件 <iterator>
template<class I>

    concept incrementable =
        std::regular<I> &&
        std::weakly_incrementable<I> &&
        requires(I i) {
            { i++ } -> std::same_as<I>;

        };
(C++20 起)

另外,给定类型 I 的二个可自增对象 abI 仅若满足下列条件才实现 std::incrementable

  • bool(a == b) 蕴含 bool(a++ == b) ,且
  • bool(a == b) 蕴含 bool(((void)a++, a) == ++b)

此概念指定能以前后自增运算符自增的类型上的要求,其自增运算必须保持相等性,且类型为 std::equality_comparable

不同于仅支持单趟算法的 std::weakly_incrementable ,实现 std::incrementable 的类型可用于多趟单方向算法。

相等性保持

若表达式对给定的相等输入产生相等输出,则它保持相等性

  • 表达式的输入由其运算数组成。
  • 表达式的输出由其结果和表达式所修改的所有运算数(若存在)组成。

进一步要求每个要求保持相等性的表达式都稳定:这种表达式带相同输入对象的二次求值必须拥有相等的输出,而无任何对这些输入对象的显式中间修改。

除非另外提醒,每个用于 requires 表达式中的表达式都要求保持相等性且稳定,而表达式的求值必须只修改其非常运算数。必须不修改常运算数。

参阅

指定 semiregular 类型能以前后自增运算符自增
(概念)
(C++20)
指定一个类型与另一类型相同
(概念)