Namespaces
Variants

std::numeric_limits<T>:: quiet_NaN

From cppreference.net
Utilities library
static T quiet_NaN ( ) throw ( ) ;
(hasta C++11)
static constexpr T quiet_NaN ( ) noexcept ;
(desde C++11)

Retorna el valor especial "quiet not-a-number ", representado por el tipo de punto flotante T . Solo tiene significado si std:: numeric_limits < T > :: has_quiet_NaN == true . En IEEE 754, la representación binaria más común de números de punto flotante, cualquier valor con todos los bits del exponente establecidos y al menos un bit de la fracción establecido representa un NaN. Está definido por la implementación qué valores de la fracción representan NaNs silenciosos o de señalización, y si el bit de signo es significativo.

Contenidos

Valor de retorno

T std:: numeric_limits < T > :: quiet_NaN ( )
/* no especializado */ T ( )
bool false
char 0
signed char 0
unsigned char 0
wchar_t 0
char8_t (desde C++20) 0
char16_t (desde C++11) 0
char32_t (desde C++11) 0
short 0
unsigned short 0
int 0
unsigned int 0
long 0
unsigned long 0
long long (desde C++11) 0
unsigned long long (desde C++11) 0
float definido por la implementación (puede ser NAN )
double definido por la implementación
long double definido por la implementación

Notas

Un NaN nunca se compara igual a sí mismo. Copiar un NaN puede no preservar su representación de bits.

Ejemplo

Varias formas de generar un NaN (la cadena de salida es específica del compilador):

#include <iostream>
#include <limits>
#include <cmath>
int main()
{
    std::cout << std::numeric_limits<double>::quiet_NaN()     << ' ' // nan
              << std::numeric_limits<double>::signaling_NaN() << ' ' // nan
              << std::acos(2)    << ' '   // nan
              << std::tgamma(-1) << ' '   // nan
              << std::log(-1)    << ' '   // nan
              << std::sqrt(-1)   << ' '   // -nan
              << 0 / 0.0         << '\n'; // -nan
    std::cout << "NaN == NaN? " << std::boolalpha
              << ( std::numeric_limits<double>::quiet_NaN() ==
                   std::numeric_limits<double>::quiet_NaN() ) << '\n';
}

Salida posible:

nan nan nan nan nan -nan -nan
NaN == NaN? false

Véase también

identifica los tipos de punto flotante que pueden representar el valor especial "not-a-number silencioso" (NaN)
(constante de miembro estática pública)
devuelve un valor NaN de señalización del tipo de punto flotante dado
(función de miembro estática pública)
(C++11) (C++11) (C++11)
not-a-number (NaN)
(función)
(C++11)
comprueba si el número dado es NaN
(función)