命名空间
变体
操作

FE_DIVBYZERO、FE_INEXACT、FE_INVALID、FE_OVERFLOW、FE_UNDERFLOW、FE_ALL_EXCEPT

来自 cppreference.com
< cpp‎ | numeric‎ | fenv
 
 
 
浮点环境
函数
(C++11)(C++11)
(C++11)(C++11)
宏常量
FE_ALL_EXCEPTFE_DIVBYZEROFE_INEXACTFE_INVALIDFE_OVERFLOWFE_UNDERFLOW
(C++11)(C++11)(C++11)(C++11)(C++11)(C++11)
(C++11)
 
定义在头文件 <cfenv>
#define FE_DIVBYZERO    /*实现定义的 2 的幂*/
(自 C++11 起)
#define FE_INEXACT      /*实现定义的 2 的幂*/
(自 C++11 起)
#define FE_INVALID      /*实现定义的 2 的幂*/
(自 C++11 起)
#define FE_OVERFLOW     /*实现定义的 2 的幂*/
(自 C++11 起)
#define FE_UNDERFLOW    /*实现定义的 2 的幂*/
(自 C++11 起)
#define FE_ALL_EXCEPT   FE_DIVBYZERO | FE_INEXACT | \

                        FE_INVALID | FE_OVERFLOW |  \

                        FE_UNDERFLOW
(自 C++11 起)

所有这些宏常量(除了 FE_ALL_EXCEPT)都扩展为不同的 2 的幂的整型常量表达式,这些表达式唯一地标识所有支持的浮点异常。每个宏只有在支持时才定义。

宏常量 FE_ALL_EXCEPT 扩展为所有其他 FE_* 的按位或,始终定义,如果实现不支持浮点异常,则为零。

常量 解释
FE_DIVBYZERO 在先前的浮点运算中发生了极点错误
FE_INEXACT 不精确结果:需要舍入才能存储先前浮点运算的结果
FE_INVALID 在先前的浮点运算中发生了域错误
FE_OVERFLOW 先前浮点运算的结果太大而无法表示
FE_UNDERFLOW 先前浮点运算的结果是次正规数,并导致精度损失
FE_ALL_EXCEPT 所有支持的浮点异常的按位或

实现可能会在 <cfenv> 中定义额外的宏常量来标识额外的浮点异常。所有这些常量都以 FE_ 开头,后跟至少一个大写字母。

有关更多详细信息,请参见 math_errhandling

[编辑] 示例

#include <cfenv>
#include <cmath>
#include <iostream>
 
// #pragma STDC FENV_ACCESS ON
 
volatile double zero = 0.0; // volatile not needed where FENV_ACCESS is supported
volatile double one = 1.0;  // volatile not needed where FENV_ACCESS is supported
 
int main()
{
    std::feclearexcept(FE_ALL_EXCEPT);
    std::cout <<  "1.0/0.0 = " << 1.0 / zero << '\n';
    if (std::fetestexcept(FE_DIVBYZERO))
        std::cout << "division by zero reported\n";
    else
        std::cout << "division by zero not reported\n";
 
    std::feclearexcept(FE_ALL_EXCEPT);
    std::cout << "1.0/10 = " << one / 10 << '\n';
    if (std::fetestexcept(FE_INEXACT))
        std::cout << "inexact result reported\n";
    else
        std::cout << "inexact result not reported\n";
 
    std::feclearexcept(FE_ALL_EXCEPT);
    std::cout << "sqrt(-1) = " << std::sqrt(-1) << '\n';
    if (std::fetestexcept(FE_INVALID))
        std::cout << "invalid result reported\n";
    else
        std::cout << "invalid result not reported\n";
}

可能的输出

1.0/0.0 = inf
division by zero reported
1.0/10 = 0.1
inexact result reported
sqrt(-1) = -nan
invalid result reported

[编辑] 另请参阅

定义常用数学函数使用的错误处理机制
(宏常量) [编辑]
C 文档 for 浮点异常宏