- cfenv[meta header]
- std[meta namespace]
- function[meta id-type]
- cpp11[meta cpp]
namespace std {
int fegetround();
}
浮動小数点数の現在の丸め方式を取得する。
現在設定されている浮動小数点数の丸め方式を返す。
#include <iostream>
#include <cfenv>
void print_round_mode(int round_mode)
{
switch (round_mode) {
case FE_DOWNWARD: std::cout << "downward" << std::endl; break;
case FE_TONEAREST: std::cout << "to nearest" << std::endl; break;
case FE_TOWARDZERO: std::cout << "toward zero" << std::endl; break;
case FE_UPWARD: std::cout << "upward" << std::endl; break;
}
}
int main()
{
// デフォルト (FE_TONEAREST)
print_round_mode(std::fegetround());
// 切り下げに設定する
std::fesetround(FE_DOWNWARD);
print_round_mode(std::fegetround());
}
- std::fegetround[color ff0000]
- std::fesetround[link fesetround.md]
- FE_DOWNWARD[link fe_downward.md]
- FE_TONEAREST[link fe_tonearest.md]
- FE_TOWARDZERO[link fe_towardzero.md]
- FE_UPWARD[link fe_upward.md]
to nearest
downward
- 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)
が必要。さもなくば、正しく動作しないおそれがある。
- コンパイルオプション