isnan
来自cppreference.com
                    
                                        
                    
                    
                                                            
                    |   定义于头文件  <math.h>
  | 
||
|   #define isnan(arg) /* implementation defined */  | 
(C99 起) | |
确定给定的浮点数 arg 是否非数( NaN )值。该宏返回整数值。
忽略 FLT_EVAL_METHOD :即使以多于参数类型的范围和精度对它求值,首先仍将它转换到其语义类型,然后分类基于该类型。
参数
| arg | - | 浮点值 | 
返回值
若 arg 为 NaN 则为非零整数值,否则为 0 。
注意
有多个拥有不同符号位和载荷的不同 NaN 值,参阅 nan 。
NaN 值决不与自身或其他 NaN 值比较相等。复制 NaN 可能改变其位模式。
另一种测试浮点值是否 NaN 的方式是与自身比较: _Bool is_nan(double x) { return x != x; } 。
示例
运行此代码
#include <stdio.h> #include <math.h> #include <float.h> int main(void) { printf("isnan(NAN) = %d\n", isnan(NAN)); printf("isnan(INFINITY) = %d\n", isnan(INFINITY)); printf("isnan(0.0) = %d\n", isnan(0.0)); printf("isnan(DBL_MIN/2.0) = %d\n", isnan(DBL_MIN/2.0)); printf("isnan(0.0 / 0.0) = %d\n", isnan(0.0/0.0)); printf("isnan(Inf - Inf) = %d\n", isnan(INFINITY - INFINITY)); }
可能的输出:
isnan(NAN) = 1 isnan(INFINITY) = 0 isnan(0.0) = 0 isnan(DBL_MIN/2.0) = 0 isnan(0.0 / 0.0) = 1 isnan(Inf - Inf) = 1
引用
- C11 standard (ISO/IEC 9899:2011):
 
- 7.12.3.4 The isnan macro (p: 236-237)
 
- C99 standard (ISO/IEC 9899:1999):
 
- 7.12.3.4 The isnan macro (p: 217)
 
参阅
|    (C99)(C99)(C99)  | 
   返回 NaN (非数)   (函数)  | 
|    (C99)  | 
   对给定的浮点值分类   (宏函数)  | 
|    (C99)  | 
   检查给定数是否具有有限值   (宏函数)  | 
|    (C99)  | 
   检查给定数是否是无穷大   (宏函数)  | 
|    (C99)  | 
   检查给定数是否正规   (宏函数)  | 
|    (C99)  | 
   检查两个浮点数值是否无序  (宏函数)  |