- cfenv[meta header]
- macro[meta id-type]
- cpp11[meta cpp]
#define FE_INEXACT integer-constant-expression
// または
#undef FE_INEXACT- integer-constant-expression[italic]
浮動小数点数の演算が不正確な結果となったことを表す浮動小数点例外の種類。
処理系がこの浮動小数点例外に対応している場合にこのマクロが定義される。
マクロが定義されるとき、このマクロは浮動小数点例外の状態を表すビット値である。他の浮動小数点例外マクロとAND (&) や OR (|)を使用して、複数のマクロを組み合わせて使用できる。
#include <iostream>
#include <cfenv>
int main()
{
// 整数に収まらない浮動小数点数から整数への変換
int result = 1.2f;
if (std::fetestexcept(FE_INEXACT)) {
std::cout << "raised inexact" << std::endl;
}
else {
std::cout << "no error" << std::endl;
}
}- FE_INEXACT[color ff0000]
- std::fetestexcept[link fetestexcept.md]
raised inexact
- C++11
- Clang: 3.0 [mark verified]
- GCC: 4.3.0 [mark verified]
- ICC: ??
- Visual C++: 2013 [mark verified], 2015 [mark verified]
- コンパイルオプション
/fp:strictまたは#pragma fenv_access (on)が必要。さもなくば、正しく動作しないおそれがある。
- コンパイルオプション