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 − true for international representations, false otherwise. 这在内部用于实例化正确的 moneypunct 类。
返回值
它返回未指定。 此函数只能用作流操纵器。
通过修改流的内部状态标志来发出错误信号 −
flag | error |
---|---|
failbit | 函数格式化mon失败(如果sentry构造失败也可以设置)。 |
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