std:: isunordered
|
Défini dans l'en-tête
<cmath>
|
||
| (1) | ||
|
bool
isunordered
(
float
x,
float
y
)
;
bool
isunordered
(
double
x,
double
y
)
;
|
(depuis C++11)
(jusqu'à C++23) |
|
|
constexpr
bool
isunordered
(
/* floating-point-type */
x,
/* floating-point-type */ y ) ; |
(depuis C++23) | |
|
Défini dans l'en-tête
<cmath>
|
||
|
template
<
class
Arithmetic1,
class
Arithmetic2
>
bool isunordered ( Arithmetic1 x, Arithmetic2 y ) ; |
(A) |
(depuis C++11)
(constexpr depuis C++23) |
Table des matières |
Paramètres
| x, y | - | valeurs à virgule flottante ou entières |
Valeur de retour
true si soit x ou y est NaN, false sinon.
Notes
Les surcharges supplémentaires ne sont pas tenues d'être fournies exactement comme (A) . Elles doivent seulement être suffisantes pour garantir que pour leur premier argument num1 et second argument num2 :
|
(jusqu'en C++23) |
|
Si
num1
et
num2
ont des types arithmétiques, alors
std
::
isunordered
(
num1, num2
)
a le même effet que
std
::
isunordered
(
static_cast
<
/*common-floating-point-type*/
>
(
num1
)
,
Si aucun tel type à virgule flottante avec le plus grand rang et la plus grande sous-catégorie n'existe, alors la résolution de surcharge ne résulte pas en un candidat utilisable parmi les surcharges fournies. |
(depuis C++23) |
Exemple
#include <cmath> #include <iostream> #define SHOW_UNORDERED(x, y) \ std::cout << std::boolalpha << "isunordered(" \ << #x << ", " << #y << "): " \ << std::isunordered(x, y) << '\n' int main() { SHOW_UNORDERED(10, 01); SHOW_UNORDERED(INFINITY, NAN); SHOW_UNORDERED(INFINITY, INFINITY); SHOW_UNORDERED(NAN, NAN); }
Sortie :
isunordered(10, 01): false isunordered(INFINITY, NAN): true isunordered(INFINITY, INFINITY): false isunordered(NAN, NAN): true
Voir aussi
|
(C++11)
|
catégorise la valeur à virgule flottante donnée
(fonction) |
|
(C++11)
|
vérifie si le nombre donné est NaN
(fonction) |
|
Documentation C
pour
isunordered
|
|