命名空间
变体
操作

std::num_put

来自 cppreference.cn
< cpp‎ | locale
 
 
 
 
 
定义于头文件 <locale>
template<

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

> class num_put;

std::num_put 封装了将数值格式化为字符串的规则。 具体而言,支持类型 bool, long, unsigned long, long long, unsigned long long(自 C++11 起), double, long double, void* 以及所有可隐式转换为这些类型的类型(例如 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 [静态] facet 的标识符

[编辑] 成员函数

构造一个新的 num_put facet
(公共成员函数)
调用 do_put
(公共成员函数)

[编辑] 受保护的成员函数

析构一个 num_put facet
(受保护的成员函数)
[虚函数]
格式化数字并写入输出流
(虚函数 受保护的成员函数)

[编辑] 示例

#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++ 标准。

DR 应用于 已发布行为 正确行为
LWG 427 C++98 num_put 保证接受任何 CharT,其
满足其上字符的要求
任何 iostream 组件都可以被实例化
仅保证接受 char,
wchar_t 和其他实现
定义的字符类型
LWG 2392 C++98 只有字符类型 CharT 可以
保证被 num_put 接受
可以保证接受实现
定义的字符容器类型

[编辑] 参见

定义数值标点规则
(类模板) [编辑]
从输入字符序列解析数值
(类模板) [编辑]
(C++11)
将整数或浮点值转换为 string
(函数) [编辑]
将整数或浮点值转换为 wstring
(函数) [编辑]