std::experimental::ranges::StrictTotallyOrdered, std::experimental::ranges::StrictTotallyOrderedWith

来自cppreference.com
< cpp‎ | experimental‎ | ranges
 
 
实验性
技术规范
文件系统库 (文件系统 TS)
库基础 (库基础 TS)
库基础 2 (库基础 TS v2)
库基础 3 (库基础 TS v3)
并行扩展 (并行 TS)
并行扩展 2 (并行 TS v2)
并发扩展 (并发 TS)
并发扩展 2 (并发 TS v2)
概念 (概念 TS)
范围 (范围 TS)
反射 (反射 TS)
数学特殊函数 (特殊函数 TR)
实验性非 TS 功能特性
模式匹配
线性代数
std::execution
契约
2D 图形
 
 
概念库
核心语言概念
                              
对象概念
                              
                              
比较概念
StrictTotallyOrderedStrictTotallyOrderedWith
可调用概念
                                        
                              
URNG 概念
 
template< class T >

concept bool StrictTotallyOrdered =
    EqualityComparable<T> &&
    requires(const std::remove_reference_t<T>& a,
             const std::remove_reference_t<T>& b) {
        { a < b }  -> Boolean&&;
        { a > b }  -> Boolean&&;
        { a <= b } -> Boolean&&;
        { a >= b } -> Boolean&&;

    };
(1) (范围 TS)
template< class T, class U >

concept bool StrictTotallyOrderedWith =
    StrictTotallyOrdered<T> &&
    StrictTotallyOrdered<U> &&
    CommonReference<
        const std::remove_reference_t<T>&,
        const std::remove_reference_t<U>&> &&
    StrictTotallyOrdered<
        ranges::common_reference_t<
            const std::remove_reference_t<T>&,
            const std::remove_reference_t<U>&>> &&
    EqualityComparableWith<T, U> &&
    requires(const std::remove_reference_t<T>& t,
             const std::remove_reference_t<U>& u) {
        { t < u }  -> Boolean&&;
        { t > u }  -> Boolean&&;
        { t <= u } -> Boolean&&;
        { t >= u } -> Boolean&&;
        { u < t }  -> Boolean&&;
        { u > t }  -> Boolean&&;
        { u <= t } -> Boolean&&;
        { u >= t } -> Boolean&&;

    };
(2) (范围 TS)
1) 概念 StrictTotallyOrdered<T> 指定 T 上的比较运算符 ==,!=,<,>,<=,>= 产出的结果与 T 上的严格全序一致。

StrictTotallyOrdered<T> 仅若符合下列条件才得到满足。给定 const std::remove_reference_t<T> 类型左值 abc

  • bool(a < b)bool(a > b)bool(a == b) 有且只有一个为 true
  • bool(a < b)bool(b < c) 均为 true,则 bool(a < c)true
  • bool(a > b) == bool(b < a)
  • bool(a >= b) == !bool(a < b)
  • bool(a <= b) == !bool(b < a)
2) 概念 StrictTotallyOrderedWith<T, U> 指定(可混合的)TU 操作数上的比较运算符 ==,!=,<,>,<=,>= 产出的结果与严格全序一致。比较混合的运算数产出的结果等价于比较转换到其共用类型的运算数。

正式而言,StrictTotallyOrderedWith<T, U> 仅若符合下列条件才得到满足。给定任何 const std::remove_reference_t<T> 类型左值 t 与任何 const std::remove_reference_t<U> 类型左值 u ,并令 Cranges::common_reference_t<const std::remove_reference_t<T>&, const std::remove_reference_t<U>&>

  • bool(t < u) == bool(C(t) < C(u))
  • bool(t > u) == bool(C(t) > C(u))
  • bool(t <= u) == bool(C(t) <= C(u))
  • bool(t >= u) == bool(C(t) >= C(u))
  • bool(u < t) == bool(C(u) < C(t))
  • bool(u > t) == bool(C(u) > C(t))
  • bool(u <= t) == bool(C(u) <= C(t))
  • bool(u >= t) == bool(C(u) >= C(t))

相等性保持

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

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

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

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

隐式表达式变种

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