Namespaces
Variants

FE_DIVBYZERO, FE_INEXACT, FE_INVALID, FE_OVERFLOW, FE_UNDERFLOW, FE_ALL_EXCEPT

From cppreference.net
Floating-point environment
Functions
(C++11) (C++11)
(C++11) (C++11)
Macro constants
FE_ALL_EXCEPT FE_DIVBYZERO FE_INEXACT FE_INVALID FE_OVERFLOW FE_UNDERFLOW
(C++11) (C++11) (C++11) (C++11) (C++11) (C++11)
(C++11)
Определено в заголовочном файле <cfenv>
#define FE_DIVBYZERO    /*implementation defined power of 2*/
(начиная с C++11)
#define FE_INEXACT      /*implementation defined power of 2*/
(начиная с C++11)
#define FE_INVALID      /*implementation defined power of 2*/
(начиная с C++11)
#define FE_OVERFLOW     /*implementation defined power of 2*/
(начиная с C++11)
#define FE_UNDERFLOW    /*implementation defined power of 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 для макросов исключений с плавающей точкой