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_* 상수들의 비트 OR로 확장되며, 항상 정의되어 있고 구현체가 부동 소수점 예외를 지원하지 않는 경우 0입니다.

상수 설명
FE_DIVBYZERO 이전 부동 소수점 연산에서 극점 오류 발생
FE_INEXACT 부정확한 결과: 이전 부동 소수점 연산 결과 저장을 위해 반올림이 필요했음
FE_INVALID 이전 부동 소수점 연산에서 정의역 오류 발생
FE_OVERFLOW 이전 부동 소수점 연산 결과가 표현 가능 범위를 초과함
FE_UNDERFLOW 이전 부동 소수점 연산 결과가 정밀도 손실과 함께 비정규 수가 됨
FE_ALL_EXCEPT 지원되는 모든 부동 소수점 예외의 비트 OR

구현은 추가적인 부동 소수점 예외를 식별하기 위해 <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 documentation for floating point exception macros