当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


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− 国际代表为真,否则为假。这在内部用于实例化正确的 moneypunct 类。

返回值

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

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

旗帜 错误
failbit 函数格式化mon失败(如果哨兵构建失败也可能被设置)。
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

相关用法


注:本文由纯净天空筛选整理自 C++ iomanip Library - put_money Function。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。