- ios[meta header]
- function[meta id-type]
- std[meta namespace]
- ios_base[meta class]
fmtflags flags() const; // (1)
fmtflags flags(fmtflags fmtfl); // (2)
- fmtflags[link type-fmtflags.md]
書式フラグを取得・設定する。
- (1) なし。
- (2) 書式フラグを引数
fmtfl
に設定する。
- (1) 現在の書式フラグ
- (2) 設定される前の書式フラグ
(2) の形式ではすべての書式フラグの設定を行ってしまうため、特定の書式フラグを変更するのにはあまり向かないが、書式フラグを一時的に変更した後に元に戻す際には便利である。
それ以外の用途では、一般的に setf
、unsetf
を使用したり、各種マニピュレータを使用する方が便利である。
#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';
}
- flags()[color ff0000]
- fmtflags[link type-fmtflags.md]
- setf[link setf.md]
- std::hex[link ../hex.md]
- hex[link type-fmtflags.md]
64
100
64
100
64
100
- C++98
- Clang: 3.0 [mark verified], 3.1 [mark verified], 3.2 [mark verified], 3.3 [mark verified], 3.4 [mark verified], 3.5.0 [mark verified], 3.6.0 [mark verified], 3.7.0 [mark verified], 3.8.0 [mark verified]
- GCC: 4.3.6 [mark verified], 4.4.7 [mark verified], 4.5.4 [mark verified], 4.6.4 [mark verified], 4.7.3 [mark verified], 4.8.1 [mark verified], 4.8.2 [mark verified], 4.9.0 [mark verified], 4.9.1 [mark verified], 4.9.2 [mark verified], 5.1.0 [mark verified], 5.2.0 [mark verified], 6.0.0 [mark verified]
- ICC: ??
- Visual C++: ??