ios_baseC++標準程式庫中的一個類,定義於<ios>頭文件中。ios_base類封裝了C++標準中的流輸入輸出中不依賴於讀寫的數據的類型的基本信息,如格式化信息、異常狀態、事件回調函數等。

C++程序設計時,一般不會直接調用std::ios_base的成員函數,但是會經常用到該類中定義的各種流的數據格式的枚舉值常量。如ios_base::hex、ios_base::skipws等等。

保存的各種信息

編輯

在類std::ios_base中,保存了下述關於流的信息:

  • 格式控制信息的枚舉類型fmtflags ,影響到如何解釋輸入序列的格式、如何生成輸出序列的格式,例如整數是16進制還是10進制表示,浮點數是科學計數法還是定點形式等;
  • 流的狀態的枚舉類型iostate,如數據是否完整、是否到達流的末尾、是否讀寫失敗等;
  • 流的打開方式的枚舉類型openmode,如讀取、寫入、追加、創建時刪除原內容、二進制打開、
  • 流的定位位置的枚舉類型seekdir,如開始位置、當前位置、結尾位置等。
  • 流的事件的枚舉類型event,如「擦除」事件erase_event,改變locale設置事件imbue_event,複製格式事件copyfmt_event。
  • 流的私用的其它額外保存的數據,為一個long型數組與一個指針數組。
  • 一個成員類failure,用於作為C++標準中的流輸入輸出類庫拋出的各種異常的基類。
  • 一個成員類Init,用於封裝cout、cin、wcout等8個靜態對象的初始化函數。

成員函數

編輯

狀態函數

編輯
  • ios_base::flags,讀取/設置流的格式。
  • ios_base::setf,設置流的格式,與原有格式合併。
  • ios_base::unsetf,根據參數mask,清除流的格式的某些位(bit)。
  • ios_base::precision,讀取/設置顯示浮點數時的精度。
  • ios_base::width,讀取/設定流的輸出數據的顯示寬度。

locale相關函數

編輯
  • ios_base::imbue,設置新的locale,並依次執行所有登記的回調函數處置imbue_event。
  • ios_base::getloc,讀取當前locale設置

靜態成員函數

編輯
  • ios_base::sync_with_stdio,設置流的內部標誌位,確定是否與C運行時庫的stdio在輸入輸出上同步。

私用數據存儲函數

編輯
  • ios_base::xalloc,返回一個對於進程中的多線程來說是唯一的一個整形值,這個值對應於流的一個內存塊的索引,該內存塊可保存一個long或者指針值。
  • ios_base::iword,根據輸入的索引值,返回流的一個內存塊的引用,可保持一個long值。
  • ios_base::pword,根據輸入的索引值,返回流的一個內存塊的引用,可保持一個指針值。

回調函數

編輯
  • ios_base::register_callback,登記一個回調函數。一個流的所有回調函數的地址保存在一個單向鍊表中。如果某個事件發生,則以登記的逆序依次調用每個回調函數。每個回調函數內部一般有個switch語句,進入相應的事件的處理分支。

構造/析構函數

編輯
  • ios_base::ios_base
  • ios_base::~ios_base:銷毀前用erase_event為參數,調用登記的回調函數。

參考文獻

編輯