std::experimental::ranges:: StrictTotallyOrdered, std::experimental::ranges:: StrictTotallyOrderedWith
|
Definido en el encabezado
<experimental/ranges/concepts>
|
||
|
template
<
class
T
>
concepto
bool
StrictTotallyOrdered
=
|
(1) | (ranges TS) |
|
template
<
class
T,
class
U
>
concepto
bool
StrictTotallyOrderedWith
=
|
(2) | (ranges TS) |
StrictTotallyOrdered<T>
especifica que los operadores de comparación
==,!=,<,>,<=,>=
en
T
producen resultados consistentes con un
orden total estricto
en
T
.
StrictTotallyOrdered<T>
se satisface solo si, dadas lvalues
a
,
b
y
c
de tipo
const
std::
remove_reference_t
<
T
>
:
- Exactamente uno de bool ( a < b ) , bool ( a > b ) y bool ( a == b ) es true ;
- Si bool ( a < b ) y bool ( b < c ) son ambos true , entonces bool ( a < c ) es true ;
- bool ( a > b ) == bool ( b < a )
- bool ( a >= b ) == ! bool ( a < b )
- bool ( a <= b ) == ! bool ( b < a )
StrictTotallyOrderedWith<T, U>
especifica que los operadores de comparación
==,!=,<,>,<=,>=
en operandos (posiblemente mixtos) de tipos
T
y
U
producen resultados consistentes con un orden total estricto. Comparar operandos mixtos produce resultados equivalentes a comparar los operandos convertidos a su tipo común.
Formalmente,
StrictTotallyOrderedWith<T, U>
se satisface solo si, dado cualquier lvalue
t
de tipo
const
std::
remove_reference_t
<
T
>
y cualquier lvalue
u
de tipo
const
std::
remove_reference_t
<
U
>
, y sea
C
el tipo
ranges::
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 ) )
Preservación de la igualdad
Una expresión es equality preserving si produce salidas iguales dadas entradas iguales.
- Las entradas de una expresión consisten en sus operandos.
- Las salidas de una expresión consisten en su resultado y todos los operandos modificados por la expresión (si los hay).
Toda expresión que deba preservar la igualdad debe además ser estable : dos evaluaciones de dicha expresión con los mismos objetos de entrada deben producir salidas iguales, a menos que exista una modificación explícita e intermedia de esos objetos de entrada.
A menos que se indique lo contrario, cada expresión utilizada en una requires-expression debe ser de preservación de igualdad y estable, y la evaluación de la expresión solo puede modificar sus operandos no constantes. Los operandos que son constantes no deben modificarse.
Variaciones de expresión implícita
Una requires-expression que utiliza una expresión que es no modificadora para algún operando constante lvalue también requiere implícitamente variaciones adicionales de esa expresión que acepten un lvalue no constante o un rvalue (posiblemente constante) para el operando dado, a menos que dicha variación de expresión sea explícitamente requerida con semántica diferente. Estas variaciones de expresión implícitas deben cumplir los mismos requisitos semánticos de la expresión declarada. El grado en que una implementación valida la sintaxis de las variaciones no está especificado.