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