描述
该函数首先构造一个类型为 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。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。