isnan
isnan
在头文件 | | |
---|---|---|
#define isnan(arg) /* implementation defined */ | | (since C99) |
确定给定的浮点数arg
是否为非数字(NaN)值。该宏返回一个整数值。
FLT_EVAL_METHOD
被忽略:即使参数的计算范围和精度超过其类型,它首先会转换为其语义类型,并且分类基于此(如果评估类型支持NaN,则语义类型不重要)。
参数
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标准(ISO / IEC 9899:2011):