Namespaces
Variants

std::numeric_limits<T>:: quiet_NaN

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

返回由浮点类型 T 表示的“静默 非数 ”特殊值。仅当 std:: numeric_limits < T > :: has_quiet_NaN == true 时才有意义。在 IEEE 754(最常用的浮点数二进制表示标准)中,任何指数位全为1且小数部分至少有一位为1的值均表示非数。具体哪些小数位组合表示静默非数或信令非数,以及符号位是否具有意义,均由实现定义。

目录

返回值

T std:: numeric_limits < T > :: quiet_NaN ( )
/* 非特化版本 */ T ( )
bool false
char 0
signed char 0
unsigned char 0
wchar_t 0
char8_t (自 C++20 起) 0
char16_t (自 C++11 起) 0
char32_t (自 C++11 起) 0
short 0
unsigned short 0
int 0
unsigned int 0
long 0
unsigned long 0
long long (自 C++11 起) 0
unsigned long long (自 C++11 起) 0
float 由实现定义(可能为 NAN
double 由实现定义
long double 由实现定义

注释

NaN 永远不会与自身相等。复制 NaN 可能无法保留其位表示形式。

示例

生成 NaN 的几种方法(输出字符串取决于编译器):

#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';
}

可能的输出:

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

参见

标识可表示特殊值“静默非数”(NaN)的浮点类型
(公开静态成员常量)
返回给定浮点类型的信令NaN值
(公开静态成员函数)
(C++11) (C++11) (C++11)
非数字(NaN)
(函数)
(C++11)
检查给定数值是否为NaN
(函数)