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

FE_OVERFLOW宏


概要:

#define FE_OVERFLOW value //value值由实现定义,为2的N次方。


描述:

该宏表示溢出范围异常,该宏会扩展为int类型的常量表达式,其值是2N次方。如果结果是个绝对值很大的有限值,以至于在没有异常舍入误差的情况下无法使用对象指定的类型表示结果,将发生溢出范围异常。如果发生溢出范围异常,并且默认的舍入生效,函数将根据返回类型和正确值的符号返回一个正或者负HUGE_VAL(或者HUGE_VALF或者HUGE_VALL)值。

当且仅当实现通过feclearexceptfegetexceptflagferaiseexceptfesetexceptflagfetestexcept函数支持浮点异常时,宏FE_OVERFLOW才会被定义。


范例:
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 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
/*宏FE_OVERFLOW范例*/

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

#pragma STDC FENV_ACCESS ON

void showExceptions(void)
{
    printf("Exceptions: ");
    /*判断是否设置浮点异常。*/
    if(fetestexcept(FE_ALL_EXCEPT)==0)
    {
        puts("No floating-point status flag is set.");
    }
    else
    {
    	/*判断设置的浮点异常。*/
        if(fetestexcept(FE_DIVBYZERO))
            printf("FE_DIVBYZERO ");
        if(fetestexcept(FE_INEXACT))
            printf("FE_INEXACT ");
        if(fetestexcept(FE_INVALID))
            printf("FE_INVALID ");
        if(fetestexcept(FE_OVERFLOW))
            printf("FE_OVERFLOW ");
        if(fetestexcept(FE_UNDERFLOW))
            printf("FE_UNDERFLOW ");
        puts("");
    }
    
    /*清除设置的浮点异常。*/
    feclearexcept(FE_ALL_EXCEPT);
}

int main(void)
{
    feclearexcept(FE_ALL_EXCEPT);
    double result = exp(1000.0);
    showExceptions();

    return 0;
}


输出:

Exceptions: FE_INEXACT FE_OVERFLOW

在这个例子中,exp(1000.0)函数的返回值已经超出了double类型所能表示的范围。


相关内容:
FE_ALL_EXCEPT 表示所有异常的宏。
FE_DIVBYZERO 表示极点异常的宏。
FE_INEXACT 表示不准确结果异常的宏。
FE_INVALID 表示域异常的宏。
FE_UNDERFLOW 表示下溢范围异常的宏。