目录

put_money

描述 (Description)

此函数首先构造一个basic_ostream :: sentry类型的对象来访问输出序列。 然后(如果评估sentry对象为true),它调用money_put :: put(使用流的选定语言环境)来执行格式化和插入操作,相应地调整流的内部状态标志。 最后,它会在返回之前摧毁哨兵对象。

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

声明 (Declaration)

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

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

参数 (Parameters)

mon - 货币价值。 moneyT应该是long double或basic_string实例化。

intl - 对于国际表示为true,否则为false。 这在内部用于实例化适当的moneypunct类。

返回值 (Return Value)

它返回未指定。 此功能仅应用作流操纵器。

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

错误
failbit 该函数无法格式化mon(如果哨兵的构造失败,也可以设置它)。
badbit 流上的插入失败,或者发生了其他一些错误(例如当此函数捕获内部操作抛出的异常时)。设置时,流的完整性可能已受到影响。

异常 (Exceptions)

Basic guarantee - 如果抛出异常,则对象处于有效状态。

Basic guarantee - 如果抛出异常,则对象处于有效状态。

如果生成的错误状态标志不是goodbit并且成员异常被设置为针对该状态抛出,则会抛出成员类型失败的异常。

内部操作抛出的任何异常都由函数捕获和处理,设置badbit。 如果在最后一次调用异常时设置了badbit,则该函数会重新捕获捕获的异常。

数据竞争 (Data races)

修改插入它的流对象。

当与stdio同步时,对标准流对象(cout,cerr,clog,wcout,wcerr和wclog)除外,对同一流对象的并发访问可能导致数据争用(在这种情况下,没有启动数据争用,尽管没有保证按插入多个线程的字符的顺序给出。

例子 (Example)

在下面的例子中解释了put_money函数。

#include <iostream>
#include <iomanip>
int main () {
   std::cout << "Price:" << std::put_money(10.50L) << '\n';
   return 0;
}

让我们编译并运行上面的程序,这将产生以下结果 -

Price:10
↑回到顶部↑
WIKI教程 @2018