C++ iomanip 库 - put_money 函数



描述

此函数首先构造一个 basic_ostream::sentry 类型的对象来访问输出序列。然后(如果求值 sentry 对象为真),它调用 money_put::put(使用流选择的区域设置)来执行格式化和插入操作,并相应地调整流的内部状态标志。最后,它在返回之前销毁 sentry 对象。

它用于将 mon 的表示形式作为货币值插入到应用于它的输出流中。

声明

以下是 std::put_money 函数的声明。

template <class moneyT>
/*unspecified*/ put_money (const moneyT& mon, bool intl = false);

参数

mon − 货币值。moneyT 应为 long double 或 basic_string 实例。

intl − 国际表示为 true,否则为 false。这在内部用于实例化正确的 moneypunct 类。

返回值

它返回未指定的值。此函数只能用作流操作符。

错误通过修改流的内部状态标志来发出信号:

标志 错误
failbit 函数未能格式化 mon(如果 sentry 的构造失败,也可能会设置此标志)。
badbit 流上的插入失败,或发生其他错误(例如,当此函数捕获内部操作抛出的异常时)。设置后,流的完整性可能已受到影响。

异常

基本保证 - 如果抛出异常,则对象处于有效状态。

基本保证 - 如果抛出异常,则对象处于有效状态。

如果结果错误状态标志不是 goodbit 并且成员异常设置为为此状态抛出,则它会抛出一个成员类型为 failure 的异常。

内部操作抛出的任何异常都会被函数捕获并处理,并设置 badbit。如果在上次调用 exceptions 时设置了 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
iomanip.htm
广告