std::money_put

来自cppreference.com
< cpp‎ | locale
 
 
本地化库
本地环境与平面
本地环境
平面类别基类
ctype(字符类别)平面
numeric(数值)平面
collate(对照比较)平面
time(时间)平面
monetary(货币)平面
money_put
messages(消息)平面
字符分类与转换
字符分类
转换
编码转换平面
(C++11)    
C 本地环境
 
 
在标头 <locale> 定义
template<

    class CharT,
    class OutputIt = std::ostreambuf_iterator<CharT>

> class money_put;

std::money_put 封装格式化货币值为字符串所用的规则。标准输入/输出操纵符 std::put_money 使用输入/输出流的本地环境的 std::money_put 平面。

cpp/locale/locale/facetstd-money put-inheritance.svg

继承图

如果标准库不保证提供 std::money_put 的某个特化(见下文),那么它的成员函数 put()do_put() 不保证会遵守指定的行为。

特化

标准库保证提供以下特化(所有本地环境对象都需要实现这些特化):

在标头 <locale> 定义
std::money_put<char> 创建货币值的窄字符串表示
std::money_put<wchar_t> 创建货币值的宽窄字符串表示

另外,标准库也保证提供满足以下类型要求的所有特化:

成员类型

成员类型 定义
char_type CharT
string_type std::basic_string<CharT>
iter_type OutputIt

成员函数

构造新的 money_put 平面
(公开成员函数)
销毁 money_put 平面
(受保护成员函数)
调用 do_put
(公开成员函数)

受保护成员函数

[虚]
格式化货币值并写入到输出流
(虚受保护成员函数)

成员对象

static std::locale::id id
本地环境的 id
(公开成员对象)

示例

#include <iostream>
#include <locale>
#include <iomanip>
#include <iterator>
 
int main()
{
    // 使用输入/输出操纵符
    std::cout.imbue(std::locale("en_US.UTF-8"));
    std::cout << "美国本地环境:"
               << std::showbase << std::put_money(12345678.9)<< '\n';
 
    // 直接使用平面
    std::cout.imbue(std::locale("de_DE.UTF-8"));
    std::cout << "德国本地环境:";
    auto& f = std::use_facet<std::money_put<char>>(std::cout.getloc());
    f.put({std::cout}, true, std::cout, std::cout.fill(), 12345678.9 );
    std::cout << '\n';
}

输出:

美国本地环境:$123,456.79
德国本地环境:123.456,79 EUR

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 427 C++98 money_put 可以接受任何满足实例化所有
iostream 组件所需的对字符类型的要求的 CharT
只保证接受 char
wchar_t,其他类型由实现定义

参阅

定义 std::money_getstd::money_put 所用的货币格式解析器的参数
(类模板)
从输入字符序列中解析并构造货币值
(类模板)
(C++11)
格式化并输出货币值
(函数模板)