std::setiosflags
From cppreference.com
| ヘッダ <iomanip>で定義 |
||
| /* unspecified */ setiosflags( std::ios_base::fmtflags mask ); |
||
式 out << setiosflags(mask) または in >> setiosflags(mask) で使用されると、ストリーム out または in のすべてのフォーマットフラグを、mask で指定されたとおりに設定します。
目次 |
[編集] パラメータ
| mask | - | 設定するフラグのビットマスク |
[編集] 戻り値
未指定の型のオブジェクト。その結果、
- out が std::basic_ostream<CharT, Traits> 型のオブジェクトである場合、式 out << setiosflags(mask) は
- は std::basic_ostream<CharT, Traits>& 型を持ち、
outの値を持ち、- f(out, mask) を呼び出したかのように動作します。
- in が std::basic_istream<CharT, Traits> 型のオブジェクトである場合、式 in >> setiosflags(mask) は
- std::basic_istream<CharT, Traits>& 型
- in の値
- f(in, mask) を呼び出したかのように動作します。
ここで関数 f は次のように定義されます。
void f(std::ios_base& str, std::ios_base::fmtflags mask) { // set specified flags str.setf(mask); }
[編集] 例
このコードを実行
#include <iomanip> #include <iostream> int main() { std::cout << std::resetiosflags(std::ios_base::dec) << std::setiosflags( std::ios_base::hex | std::ios_base::uppercase | std::ios_base::showbase) << 42 << '\n'; }
出力
0X2A
[編集] 欠陥レポート
以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。
| DR | 適用対象 | 公開された動作 | 正しい動作 |
|---|---|---|---|
| LWG 183 | C++98 | setiosflags はストリームでのみ使用可能でした。任意の文字ストリームで使用可能 |
(誤字のため、17番の「任意の文字ストリームで使用可能」は18番として扱われるべきですが、提供されたHTML構造に従います。) (19番は提供されたHTML構造には対応する要素がありません。) |
[編集] 関連項目
| 特定の書式フラグを設定する ( std::ios_base の public メンバ関数) | |
| 指定されたios_baseフラグをクリアする (関数) |