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

FE_INEXACT宏


概要:

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


描述:

该宏表示不准确结果异常,该宏会扩展为int类型的常量表达式,其值是2N次方。当函数由于某种原因不能得到准确的结果或者操作的返回类型不能以准确的精度表示结果时,会引发不准确结果异常。

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


范例:
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_INEXACT范例*/

#include <fenv.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 number = 1.0;
    double result = number/3.0;
    showExceptions();

    return 0;
}


输出:

Exceptions: FE_INEXACT


相关内容:
FE_ALL_EXCEPT 表示所有异常的宏。
FE_DIVBYZERO 表示极点异常的宏。
FE_INVALID 表示域异常的宏。
FE_OVERFLOW 表示溢出范围异常的宏。
FE_UNDERFLOW 表示下溢范围异常的宏。