名稱空間
變體
操作

std::moneypunct<CharT,International>::pos_format, do_pos_format, neg_format, do_neg_format

來自 cppreference.com
 
 
 
 
 
定義於標頭檔案 <locale>
public:
pattern pos_format() const;
(1)
public:
pattern neg_format() const;
(2)
protected:
virtual pattern do_pos_format() const;
(3)
protected:
virtual pattern do_neg_format() const;
(4)
1) 公有成員函式,呼叫派生程度最高的類中的成員函式 do_pos_format
2) 公有成員函式,呼叫派生程度最高的類中的成員函式 do_neg_format
3) 返回描述正貨幣值格式的格式結構(型別為 std::money_base::format)。
4) 返回描述負貨幣值格式的格式結構(型別為 std::money_base::format)。

std::moneypunct 的標準特化返回模式 {symbol, sign, none, value}

目錄

[編輯] 返回值

型別為 std::money_base::format 的物件,描述此區域設定所用的格式。

[編輯] 注意

儘管 std::money_put 使用 pos_format 來格式化正值,使用 neg_format 來格式化負值,但 std::money_get 使用 neg_format 來解析所有貨幣值:它假定 neg_formatpos_format 相容。

[編輯] 示例

#include <iomanip>
#include <iostream>
#include <locale>
 
struct my_punct : std::moneypunct_byname<char, false>
{
    my_punct(const char* name) : moneypunct_byname(name) {}
    pattern do_pos_format() const { return {value, space, symbol, sign}; }
    pattern do_neg_format() const { return {value, space, symbol, sign}; }
};
 
int main()
{
    std::cout.imbue(std::locale("en_US.utf8"));
    std::cout << "american locale: " << std::showbase
              << std::put_money(12345678.0) << '\n';
 
    std::cout.imbue(std::locale(std::cout.getloc(), new my_punct("en_US.utf8")));
    std::cout << "locale with modified moneypunct:\n"
              << std::put_money(12345678.0) << '\n'
              << std::put_money(-12345678.0) << '\n';
}

輸出

american locale: $123,456.78
locale with modified moneypunct:
123,456.78 $
123,456.78 $-

[編輯] 參閱

提供用作貨幣識別符號的字串
(虛保護成員函式) [編輯]
提供指示正值或負值的字串
(虛保護成員函式) [編輯]
[虛]
從輸入流解析貨幣值
(std::money_get<CharT,InputIt> 的虛保護成員函式) [編輯]
[虛]
格式化貨幣值並寫入輸出流
(std::money_put<CharT,OutputIt> 的虛保護成員函式) [編輯]