最終更新日時:
が更新

履歴 編集

function
<cfenv>

std::fegetround(C++11)

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());
}

出力

to nearest
downward

バージョン

言語

  • C++11

処理系

  • Clang, C++11 mode: 3.0
  • GCC, C++11 mode: 4.3.0
  • ICC: ??
  • Visual C++: 12.0, 14.0
    • コンパイルオプション/fp:strictまたは#pragma fenv_access (on)が必要。さもなくば、正しく動作しないおそれがある。