名稱空間
變體
操作

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

來自 cppreference.com
 
 
 
 
 
定義於標頭檔案 <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 <iomanip>
#include <iostream>
#include <iterator>
#include <locale>
 
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

[編輯] 參閱

提供用作千位分隔符的字元
(虛保護成員函式) [編輯]
提供用作小數點的字元
(虛保護成員函式) [編輯]