当前位置: C语言 -- 标准库 -- <math.h> -- isfinite

isfinite宏


概要:
#include <math.h>
int isfinite(real-floating x);

描述:

该宏是函数式宏(function-like macro),判断参数是否为有限值。规格化数(normal number)、次规格化数(subnormal number)、0(zero)都是有限值;非数值(NaN)、无穷大(infinite)不是有限值。

如果参数x的表示形式宽于real-floating类型,将转换成real-floating类型;然后再根据real-floating类型进行判断。


参数:
real-floating x

参数x应为实数浮点类型表达式,例如:floatdoublelong double类型表达式。


返回值:

如果参数为有限值,该宏返回非0值。


范例:
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
/*宏isfinite范例*/

#include <float.h>
#include <math.h>
#include <stdio.h>

int main(void)
{
    if(isfinite(0.0))
        puts("0.0 has a finite value.");

    if(isfinite(3.14))
        puts("3.14 has a finite value.");

    if(isfinite(DBL_MIN/2))
        puts("DBL_MIN/2 has a finite value.");

    if(isfinite(NAN))
        puts("NAN has a finite value.");

    if(isfinite(INFINITY))
        puts("INFINITY has a finite value.");

    return 0;
}

输出:

0.0 has a finite value.

3.14 has a finite value.

DBL_MIN/2 has a finite value.


相关内容:
fpclassify 对参数按浮点类别进行分类的宏。
isinf 判断参数是否为无穷大的宏。
isnan 判断参数是否为非数值的宏。
isnormal 判断参数是否为规格化数的宏。