命名空间
变体
操作

FE_DIVBYZERO, FE_INEXACT, FE_INVALID, FE_OVERFLOW, FE_UNDERFLOW, FE_ALL_EXCEPT

来自 cppreference.cn
< cpp‎ | 数值‎ | 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 文档,关于浮点异常宏