當前位置: 首頁>>編程示例 >>用法及示例精選 >>正文


C++ iomanip put_money用法及代碼示例


描述

該函數通過首先構造一個類型為 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 Library - put_money Function。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。