- ios[meta header]
- function[meta id-type]
- std[meta namespace]
- ios_base[meta class]
fmtflags setf(fmtflags fmtfl); // (1)
fmtflags setf(fmtflags fmtfl, fmtflags mask); // (2)
- fmtflags[link type-fmtflags.md]
書式フラグを設定する。
- (1)
flags
()
に引数fmtfl
を設定する。flags
(
flags
() | fmtfl)
と等価。 - (2)
flags
()
から引数mask
をクリアした後、引数fmtfl
を設定する。flags
((
flags
() & ~mask) | fmtfl)
と等価。
- (1) 設定される前の書式フラグ
- (2) 設定される前の書式フラグ
- (1) の形式は単独のビットで意味のあるフィールドに、(2) の形式は複数のビットで一つの意味を表すフィールドに用いる。(例を参照)
- 設定後に戻す必要が無いような場合には、本関数より各種マニピュレータを使用した方が便利だろう。
#include <iostream>
int main()
{
// (1) の形式
// bool をアルファベット形式で出力
std::ios_base::fmtflags old1 = std::cout.setf(std::ios_base::boolalpha);
std::cout << true << '\n';
std::cout.flags(old1);
// (2) の形式
// 16 進数に設定して出力
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 << std::boolalpha << true << std::noboolalpha << '\n';
std::cout << std::hex << 100 << std::dec << '\n';
}
- std::hex[link ../hex.md]
- std::dec[link ../dec.md]
- std::boolalpha[link ../boolalpha.md]
- std::noboolalpha[link ../noboolalpha.md]
- std::ios_base[link ../ios_base.md]
- setf[color ff0000]
- flags[link flags.md]
- fmtflags[link type-fmtflags.md]
- hex[link type-fmtflags.md]
- boolalpha[link type-fmtflags.md]
true
64
true
64
- 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++: ??