Namespaces
Variants

std:: ratio_not_equal

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
(C++11) ( DR* )
Type properties
(C++11)
(C++11)
(C++14)
(C++11) (deprecated in C++26)
(C++11) ( until C++20* )
(C++11) (deprecated in C++20)
(C++11)
Type trait constants
Metafunctions
(C++17)
Supported operations
Relationships and property queries
Type modifications
Type transformations
(C++11) (deprecated in C++23)
(C++11) (deprecated in C++23)
(C++11)
(C++11) ( until C++20* ) (C++17)

Compile-time rational arithmetic
Compile-time integer sequences
Definido en el encabezado <ratio>
template < class R1, class R2 >
struct ratio_not_equal : std:: integral_constant < bool , /* ver más abajo */ > { } ;
(desde C++11)

Si las razones R1 y R2 no son iguales, proporciona la constante miembro value igual a true . De lo contrario, value es false .

Contenidos

Plantilla de variable auxiliar

template < class R1, class R2 >
constexpr bool ratio_not_equal_v = ratio_not_equal < R1, R2 > :: value ;
(desde C++17)

Heredado de std:: integral_constant

Constantes miembro

value
[static]
true si R1 :: num ! = R2 :: num || R1 :: den ! = R2 :: den , false en caso contrario
(constante miembro pública estática)

Funciones miembro

operator bool
convierte el objeto a bool , devuelve value
(función miembro pública)
operator()
(C++14)
devuelve value
(función miembro pública)

Tipos miembro

Tipo Definición
value_type bool
type std:: integral_constant < bool , value >

Implementación posible

template< class R1, class R2 >
struct ratio_not_equal : std::integral_constant <
                              bool,
                              !std::ratio_equal<R1, R2>
                         > {};

Ejemplo

#include <ratio>
static_assert(std::ratio_not_equal_v<std::ratio<6, 9>, std::ratio<9, 6>>, "6/9 != 9/6");
int main() {}

Véase también

compara dos objetos ratio para igualdad en tiempo de compilación
(plantilla de clase)