描述
該函數通過首先構造一個類型為 basic_ostream::sentry 的對象來訪問輸出序列。然後(如果評估哨兵對象為真),它調用 money_put::put(使用流的選定區域設置)來執行格式化和插入操作,相應地調整流的內部狀態標誌。最後,它在返回之前銷毀哨兵對象。
它用於將 mon 的表示作為貨幣值插入到它所應用的輸出流中。
聲明
以下是 std::put_money 函數的聲明。
template <class moneyT>
/*unspecified*/ put_money (const moneyT& mon, bool intl = false);
參數
mon− 貨幣價值。 moneyT 應為 long double 或 basic_string 實例化。
intl− 國際代表為真,否則為假。這在內部用於實例化正確的 moneypunct 類。
返回值
它返回未指定。此函數應僅用作流操縱器。
通過修改流的內部狀態標誌來發出錯誤信號 -
旗幟 | 錯誤 |
---|---|
failbit | 函數格式化mon失敗(如果哨兵構建失敗也可能被設置)。 |
badbit | 流上的插入失敗,或者發生了其他一些錯誤(例如當此函數捕獲內部操作拋出的異常時)。設置後,流的完整性可能已受到影響。 |
異常
Basic guarantee- 如果拋出異常,則對象處於有效狀態。
Basic guarantee- 如果拋出異常,則對象處於有效狀態。
如果產生的錯誤狀態標誌不是 goodbit 並且成員異常被設置為針對該狀態拋出,則它會拋出成員類型失敗的異常。
內部操作拋出的任何異常都由函數捕獲和處理,設置 badbit。如果在上次調用異常時設置了 badbit,則該函數將重新拋出捕獲的異常。
數據競爭
修改插入的流對象。
對同一個流對象的並發訪問可能會導致數據爭用,但標準流對象(cout、cerr、clog、wcout、wcerr 和 wclog)除外,當這些對象與 stdio 同步時(在這種情況下,不會發起數據爭用,盡管沒有保證來自多個線程的字符插入的順序)。
示例
在下麵的例子中解釋了 put_money 函數。
#include <iostream>
#include <iomanip>
int main () {
std::cout << "Price:" << std::put_money(10.50L) << '\n';
return 0;
}
讓我們編譯並運行上麵的程序,這將產生以下結果 -
Price:10
相關用法
- C++ iomanip put_time用法及代碼示例
- C++ iomanip setbase()用法及代碼示例
- C++ iomanip setpricision()用法及代碼示例
- C++ iomanip setiosflags()用法及代碼示例
- C++ iomanip get_money用法及代碼示例
- C++ iomanip setprecision()用法及代碼示例
- C++ iomanip setprecision用法及代碼示例
- C++ iomanip resetiosflags()用法及代碼示例
- C++ iomanip setfill()用法及代碼示例
- C++ iomanip resetiosflags用法及代碼示例
- C++ iomanip setw()用法及代碼示例
- C++ iomanip setiosflags用法及代碼示例
- C++ iomanip setfill用法及代碼示例
- C++ iomanip get_time用法及代碼示例
- C++ iomanip setbases用法及代碼示例
- C++ iomanip setw用法及代碼示例
- C++ ios eof()用法及代碼示例
- C++ ios manipulators boolalpha()用法及代碼示例
- C++ ios Scientific用法及代碼示例
- C++ ios manipulators left()用法及代碼示例
注:本文由純淨天空篩選整理自 C++ iomanip Library - put_money Function。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。