std::sized_sentinel_for, std::disable_sized_sentinel_for

< cpp‎ | iterator
 
 
迭代器库
迭代器概念
sized_sentinel_for
(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 S, class I>

  concept sized_sentinel_for =
    std::sentinel_for<S, I> &&
    !std::disable_sized_sentinel_for<std::remove_cv_t<S>, std::remove_cv_t<I>> &&
    requires(const I& i, const S& s) {
      { s - i } -> std::same_as<std::iter_difference_t<I>>;
      { i - s } -> std::same_as<std::iter_difference_t<I>>;

    };
(1) (C++20 起)
template<class S, class I>
  inline constexpr disable_sized_sentinel_for = false;
(2) (C++20 起)
1) sized_sentinel_for 概念指定能在常数时间内相减迭代器类型 I 的对象和哨位类型 S 的对象,计算其间的距离。
2) disable_sized_sentinel_for 变量模板能用于阻止能相减但不实际实现 sized_sentinel_for 的迭代器与哨位满足该概念。
允许对 cv 无限定的非数组对象类型 SI 特化该变量模板,只要其中之一是程序定义类型。这种特化必须可用于常量表达式并拥有 const bool 类型。

语义要求

iI 类型迭代器,而 sS 类型哨位,使得 [i, s) 代表范围。令 n 为需要应用 ++i 以令 bool(i == s)true 的最小次数。则 sized_sentinel_for<S, I> 仅若符合下列条件才得到实现:

  • n 能以 ranges::difference_type_t<I> 表示,则 s - i 良定义并等于 n ;且
  • -n 能以 ranges::difference_type_t<I> 表示,则 i - s 良定义并等于 -n
  • is 间的减法拥有常数时间复杂度。

相等性保持

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

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

在标准概念的规范中,操作数定义为仅包含下列内容的最大子表达式:

每个操作数的 cv 限定与值类别,是通过假设每个模板类型形参代表一个 cv 无限定的非数组对象类型确定的。

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

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

隐式表达式变种

使用不修改某 const 左值运算数的表达式的 requires 表达式亦隐式要求该表达式的额外变种对给定运算数接受非 const 左值或(可为 const 的)右值,除非以有区别的语义显式要求这种表达式变种。这些隐式表达式变种必须符合与声明的表达式的相同的语义。不指定实现以何种程度校验变种的语法。