FE_DIVBYZERO, FE_INEXACT, FE_INVALID, FE_OVERFLOW, FE_UNDERFLOW, FE_ALL_EXCEPT
From cppreference.net
|
헤더 파일에 정의됨
<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 | \
|
(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)
참조 항목
|
(C99)
(C99)
(C99)
|
일반 수학 함수에서 사용하는 오류 처리 메커니즘을 정의함
(매크로 상수) |
|
C++ 문서
for
부동 소수점 예외 매크로
|
|