名稱空間
變體
操作

std::num_put

來自 cppreference.com
< cpp‎ | locale
 
 
 
 
 
定義於標頭檔案 <locale>
template<

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

> class num_put;

std::num_put 封裝了將數值格式化為字串的規則。具體來說,支援型別 boollongunsigned longlong longunsigned long long(C++11 起)doublelong doublevoid* 以及所有可隱式轉換為這些型別的型別(例如 intfloat)。標準格式化輸出運算子(例如 cout << n;)使用 I/O 流區域設定的 std::num_put facet 來生成數字的文字表示。

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

繼承圖

如果標準庫不保證提供 std::num_put 特化(見下文),則其 put()do_put() 的行為將不保證符合規範。

目錄

[編輯] 特化

標準庫保證提供以下特化(它們 要求由任何區域設定物件實現

定義於標頭檔案 <locale>
std::num_put<char> 建立數字的窄字串表示
std::num_put<wchar_t> 建立數字的寬字串表示

此外,標準庫還保證提供滿足以下型別要求的每個特化:

[編輯] 巢狀型別

型別 定義
char_type CharT
iter_type OutputIt

[編輯] 資料成員

成員 描述
std::locale::id id [static] facet 的識別符號

[編輯] 成員函式

構造一個新的 num_put facet
(公開成員函式)
呼叫 do_put
(公開成員函式)

[編輯] 受保護成員函式

析構 num_put facet
(受保護成員函式)
[virtual]
格式化數字並寫入輸出流
(虛受保護成員函式)

[編輯] 示例

#include <iostream>
#include <iterator>
#include <locale>
#include <string>
 
int main()
{
    double n = 1234567.89;
    std::cout.imbue(std::locale("de_DE.UTF-8"));
    std::cout << "Direct conversion to string:\n"
              << std::to_string(n) << '\n'
              << "Output using a german locale:\n"
              << std::fixed << n << '\n'
              << "Output using an american locale:\n";
 
    // use the facet directly
    std::cout.imbue(std::locale("en_US.UTF-8"));
    auto& f = std::use_facet<std::num_put<char>>(std::cout.getloc());
    f.put(std::ostreambuf_iterator<char>(std::cout), std::cout, ' ', n);
    std::cout << '\n';
}

可能的輸出

Direct conversion to string:
1234567.890000
Output using a german locale:
1.234.567,890000
Output using an american locale:
1,234,567.890000

[編輯] 缺陷報告

下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。

缺陷報告 應用於 釋出時的行為 正確的行為
LWG 427 C++98 num_put 保證接受任何 CharT
滿足作為字元的要求
任何 iostream 元件都可以在其上例項化
只保證接受 char,
wchar_t 和其他實現-
定義的字元型別
LWG 2392 C++98 只有字元型別 CharT 可以
保證被 num_put 接受
可以保證接受實現-
定義的字元容器型別

[編輯] 參閱

定義數字標點規則
(類模板) [編輯]
從輸入字元序列解析數字值
(類模板) [編輯]
(C++11)
將整數或浮點值轉換為 string
(函式) [編輯]
將整數或浮點值轉換為 wstring
(函式) [編輯]