- cfenv[meta header]
- macro[meta id-type]
- cpp11[meta cpp]
# define FE_UNDERFLOW implementation-defined
浮動小数点数の演算でアンダーフローが発生したことを表す浮動小数点例外の種類。
このマクロは、浮動小数点例外の状態を表すビット値である。他の浮動小数点例外マクロとAND (&
) や OR (|
)を使用して、複数のマクロを組み合わせて使用できる。
#include <iostream>
#include <cfenv>
int main()
{
float x = 1e-30f;
float y = x * x;
if (std::fetestexcept(FE_UNDERFLOW)) {
std::cout << "raised underflow" << std::endl;
}
else {
std::cout << "no error" << std::endl;
}
}
- FE_UNDERFLOW[color ff0000]
- std::fetestexcept[link fetestexcept.md]
raised underflow
- C++11
- Clang, C++11 mode: 3.0
- GCC, C++11 mode: 4.3.0
- ICC: ??
- Visual C++: 2013, 2015
- コンパイルオプション
/fp:strict
または#pragma fenv_access (on)
が必要。さもなくば、正しく動作しないおそれがある。
- コンパイルオプション