FE_DIVBYZERO, FE_INEXACT, FE_INVALID, FE_OVERFLOW, FE_UNDERFLOW, FE_ALL_EXCEPT
From cppreference.net
|
헤더 파일에 정의됨
<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 | \
|
(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++11)
(C++11)
(C++11)
|
일반 수학 함수들이 사용하는 오류 처리 메커니즘을 정의함
(매크로 상수) |
|
C documentation
for
floating point exception macros
|
|