Namespaces
Variants

FE_DIVBYZERO, FE_INEXACT, FE_INVALID, FE_OVERFLOW, FE_UNDERFLOW, FE_ALL_EXCEPT

From cppreference.net
< c ‎ | numeric ‎ | fenv
헤더 파일에 정의됨 <fenv.h>
#define FE_DIVBYZERO    /*implementation defined power of 2*/
(C99부터)
#define FE_INEXACT      /*implementation defined power of 2*/
(C99부터)
#define FE_INVALID      /*implementation defined power of 2*/
(C99부터)
#define FE_OVERFLOW     /*implementation defined power of 2*/
(C99부터)
#define FE_UNDERFLOW    /*implementation defined power of 2*/
(C99부터)
#define FE_ALL_EXCEPT  FE_DIVBYZERO | FE_INEXACT | \

FE_INVALID | FE_OVERFLOW |  \

FE_UNDERFLOW
(C99부터)

이 모든 매크로 상수들( FE_ALL_EXCEPT 제외)은 지원되는 모든 부동 소수점 예외를 고유하게 식별하는 서로 다른 2의 거듭제곱인 정수 상수 표현식으로 확장됩니다. 각 매크로는 지원되는 경우에만 정의됩니다.

매크로 상수 FE_ALL_EXCEPT 는 다른 모든 FE_* 의 비트 OR로 확장되며, 항상 정의되어 있고 구현체에서 부동 소수점 예외를 지원하지 않는 경우 0입니다.

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

구현에서는 추가적인 부동 소수점 예외를 식별하기 위해 <fenv.h> 에 추가적인 매크로 상수를 정의할 수 있습니다. 이러한 모든 상수는 FE_ 로 시작하고 그 뒤에 최소 하나의 대문자가 옵니다.

자세한 내용은 math_errhandling 을 참조하십시오.

예제

#include <stdio.h>
#include <math.h>
#include <float.h>
#include <fenv.h>
#pragma STDC FENV_ACCESS ON
void show_fe_exceptions(void)
{
    printf("exceptions raised:");
    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");
    feclearexcept(FE_ALL_EXCEPT);
    printf("\n");
}
int main(void)
{
    printf("MATH_ERREXCEPT is %s\n",
           math_errhandling & MATH_ERREXCEPT ? "set" : "not set");
    printf("0.0/0.0 = %f\n", 0.0/0.0);
    show_fe_exceptions();
    printf("1.0/0.0 = %f\n", 1.0/0.0);
    show_fe_exceptions();
    printf("1.0/10.0 = %f\n", 1.0/10.0);
    show_fe_exceptions();
    printf("sqrt(-1) = %f\n", sqrt(-1));
    show_fe_exceptions();
    printf("DBL_MAX*2.0 = %f\n", DBL_MAX*2.0);
    show_fe_exceptions();
    printf("nextafter(DBL_MIN/pow(2.0,52),0.0) = %.1f\n",
                      nextafter(DBL_MIN/pow(2.0,52),0.0));
    show_fe_exceptions();
}

가능한 출력:

MATH_ERREXCEPT is set
0.0/0.0 = nan
exceptions raised: FE_INVALID
1.0/0.0 = inf
exceptions raised: FE_DIVBYZERO
1.0/10.0 = 0.100000
exceptions raised: FE_INEXACT
sqrt(-1) = -nan
exceptions raised: FE_INVALID
DBL_MAX*2.0 = inf
exceptions raised: FE_INEXACT FE_OVERFLOW
nextafter(DBL_MIN/pow(2.0,52),0.0) = 0.0
exceptions raised: FE_INEXACT FE_UNDERFLOW

참고문헌

  • C11 표준 (ISO/IEC 9899:2011):
  • 7.6/6 부동 소수점 환경 <fenv.h> (p: 207)
  • C99 표준 (ISO/IEC 9899:1999):
  • 7.6/5 부동 소수점 환경 <fenv.h> (p: 188)

참조 항목

일반 수학 함수에서 사용하는 오류 처리 메커니즘을 정의함
(매크로 상수)
C++ 문서 for 부동 소수점 예외 매크로