名稱空間
變體
操作

std::setiosflags

來自 cppreference.com
< cpp‎ | io‎ | manip
 
 
 
輸入/輸出操縱器
浮點格式化
整數格式化
布林格式化
欄位寬度和填充控制
其他格式化
空白字元處理
輸出重新整理
(C++20)  

狀態標誌操作
setiosflags
時間與金錢 I/O
(C++11)
(C++11)
(C++11)
(C++11)
帶引號的操縱器
(C++14)
 
定義於標頭檔案 <iomanip>
/*未指定*/ setiosflags( std::ios_base::fmtflags mask );

當在表示式 out << setiosflags(mask)in >> setiosflags(mask) 中使用時,根據 mask 設定流 outin 的所有格式標誌。

目錄

[編輯] 引數

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++ 標準。

缺陷報告 應用於 釋出時的行為 正確的行為
LWG 183 C++98 setiosflags 只能與流一起使用
型別為 std::ostreamstd::istream
可用於任何
字元流

[編輯] 另請參閱

設定特定格式標誌
(std::ios_base 的公共成員函式) [編輯]
清除指定的 ios_base 標誌
(函式) [編輯]