C
数值 | Numerics

isnormal

isnormal

在头文件中定义
#define isnormal(arg) /* implementation defined */(since C99)

确定给定的浮点数arg是否正常,即不是零,低于正常,无限,也不是NaN。该宏返回一个整数值。

FLT_EVAL_METHOD 将被忽略:即使参数的计算范围和精度比其类型更大,它首先会转换为其语义类型,并且分类将基于该类型。

参数

ARG-浮点值

返回值

非零整数值如果arg是正常的,​0​否则。

#include <stdio.h> #include <math.h> #include <float.h> int main(void) { printf("isnormal(NAN) = %d\n", isnormal(NAN) printf("isnormal(INFINITY) = %d\n", isnormal(INFINITY) printf("isnormal(0.0) = %d\n", isnormal(0.0) printf("isnormal(DBL_MIN/2.0) = %d\n", isnormal(DBL_MIN/2.0) printf("isnormal(1.0) = %d\n", isnormal(1.0) }

输出:

isnormal(NAN) = 0 isnormal(INFINITY) = 0 isnormal(0.0) = 0 isnormal(DBL_MIN/2.0) = 0 isnormal(1.0) = 1

参考

  • C11标准(ISO / IEC 9899:2011):