std::moneypunct<CharT,International>::grouping, do_grouping

来自cppreference.com
< cpp‎ | locale‎ | moneypunct
 
 
本地化库
本地环境与平面
本地环境
平面类别基类
ctype(字符类别)平面
numeric(数值)平面
collate(对照比较)平面
time(时间)平面
monetary(货币)平面
messages(消息)平面
字符分类与转换
字符分类
转换
编码转换平面
(C++11)    
C 本地环境
 
 
在标头 <locale> 定义
public:
std::string grouping() const;
(1)
protected:
virtual std::string do_grouping() const;
(2)
1) 公开成员函数,调用最终导出类的成员函数 do_grouping
2) 返回确定货币输出中数位分组的模式,含义与 std::numpunct::do_grouping 准确相同。

返回值

保有分组的 std::string 类型对象。 std::moneypunct 的标准特化返回空字符串,指示不分组。典型的分组(例如 en_US 本地环境)返回 "\003"

示例

#include <locale>
#include <iostream>
#include <iomanip>
#include <iterator>
struct space_out : std::moneypunct<char> {
    pattern do_pos_format()      const { return { {value, none, none, none} };}
    int do_frac_digits()         const { return 0; }
    char_type do_thousands_sep() const { return ' ';}
    string_type do_grouping()    const { return "\002";}
};
int main()
{
    std::cout.imbue(std::locale("en_US.UTF-8"));
    std::cout << "american locale: " << std::showbase
              << std::put_money(12345678.0)<< '\n';
 
    std::cout.imbue(std::locale(std::cout.getloc(), new space_out));
    std::cout << "locale with modified moneypunct: "
              << std::put_money(12345678.0)<< '\n';
}

输出:

american locale: $123,456.78
locale with modified moneypunct: 12 34 56 78

参阅

提供用作千分隔符的字符
(虚受保护成员函数)
提供用作小数点的字符
(虚受保护成员函数)