最終更新日時(UTC):
が更新

履歴 編集

function
<ios>

std::ios_base::flags

fmtflags flags() const;             // (1)
fmtflags flags(fmtflags fmtfl);     // (2)

概要

書式フラグを取得・設定する。

効果

  • (1) なし。
  • (2) 書式フラグを引数 fmtfl に設定する。

戻り値

  • (1) 現在の書式フラグ
  • (2) 設定される前の書式フラグ

備考

(2) の形式ではすべての書式フラグの設定を行ってしまうため、特定の書式フラグを変更するのにはあまり向かないが、書式フラグを一時的に変更した後に元に戻す際には便利である。
それ以外の用途では、一般的に setfunsetf を使用したり、各種マニピュレータを使用する方が便利である。

#include <iostream>

int main()
{
  std::cout << 100 << '\n';

  // 16 進数に設定して出力
  std::ios_base::fmtflags old1 = std::cout.flags();
  std::cout.flags((old1 & ~std::ios_base::basefield) | std::ios_base::hex);
  std::cout << 100 << '\n';

  // 基数を元に戻して出力
  std::cout.flags(old1);
  std::cout << 100 << '\n';

  // 16 進数に設定して出力(setf を使用)
  std::ios_base::fmtflags old2 = std::cout.setf(std::ios_base::hex, std::ios_base::basefield);
  std::cout << 100 << '\n';

  // 基数を元に戻して出力
  std::cout.flags(old2);
  std::cout << 100 << '\n';

  // 16 進数に設定して出力(マニピュレータを使用)
  std::ios_base::fmtflags old3 = std::cout.flags();
  std::cout << std::hex << 100 << '\n';

  // 基数を元に戻して出力
  std::cout.flags(old3);
  std::cout << 100 << '\n';
}

出力

64
100
64
100
64
100

バージョン

言語

  • C++98

処理系

  • Clang: 3.0 , 3.1 , 3.2 , 3.3 , 3.4 , 3.5.0 , 3.6.0 , 3.7.0 , 3.8.0
  • GCC: 4.3.6 , 4.4.7 , 4.5.4 , 4.6.4 , 4.7.3 , 4.8.1 , 4.8.2 , 4.9.0 , 4.9.1 , 4.9.2 , 5.1.0 , 5.2.0 , 6.0.0
  • ICC: ??
  • Visual C++: ??

参照