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
Défini dans l'en-tête <ratio>
template < class R1, class R2 >
struct ratio_not_equal : std:: integral_constant < bool , /* voir ci-dessous */ > { } ;
(depuis C++11)

Si les rapports R1 et R2 ne sont pas égaux, fournit la constante membre value égale à true . Sinon, value est false .

Table des matières

Modèle de variable d'assistance

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

Hérité de std:: integral_constant

Constantes membres

value
[static]
true si R1 :: num ! = R2 :: num || R1 :: den ! = R2 :: den , false sinon
(constante membre publique statique)

Fonctions membres

operator bool
convertit l'objet en bool , retourne value
(fonction membre publique)
operator()
(C++14)
retourne value
(fonction membre publique)

Types membres

Type Définition
value_type bool
type std:: integral_constant < bool , value >

Implémentation possible

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

Exemple

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

Voir aussi

compare deux objets ratio pour l'égalité au moment de la compilation
(modèle de classe)