std::numeric_limits<T>:: quiet_NaN
From cppreference.net
<
cpp
|
types
|
numeric limits
|
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
参见
|
[static]
|
标识可表示特殊值“静默非数”(NaN)的浮点类型
(公开静态成员常量) |
|
[static]
|
返回给定浮点类型的信令NaN值
(公开静态成员函数) |
|
(C++11)
(C++11)
(C++11)
|
非数字(NaN)
(函数) |
|
(C++11)
|
检查给定数值是否为NaN
(函数) |