std:: num_put
|
定义于头文件
<locale>
|
||
|
template
<
class
CharT,
|
||
类
std::num_put
封装了将数值格式化为字符串的规则。具体支持以下类型:
bool
、
long
、
unsigned
long
、
long
long
、
unsigned
long
long
(C++11 起)
、
double
、
long
double
、
void
*
,以及所有可隐式转换为这些类型的类型(如
int
或
float
)。标准格式化输出运算符(例如
cout
<<
n
;
)使用 I/O 流区域设置的
std::num_put
facet 来生成数字的文本表示形式。
继承关系图
如果标准库不保证提供某个
std::num_put
特化(参见下文),其
put()
和
do_put()
成员函数的行为不保证符合规范说明。
目录 |
特化
标准库保证提供以下特化(它们 是任何locale对象都必须实现的 ):
|
定义于头文件
<locale>
|
|
| std :: num_put < char > | 创建数字的窄字符串表示 |
| std :: num_put < wchar_t > | 创建数字的宽字符串表示 |
此外,标准库还保证提供满足以下类型要求的每个特化:
-
CharT是以下类型之一:- char ,
- wchar_t ,以及
- 任何其他实现定义的 字符容器类型 ,该类型需满足可在其上实例化任意 iostream组件 的字符要求;且
-
OutputIt必须满足 LegacyOutputIterator 的要求。
嵌套类型
| 类型 | 定义 |
char_type
|
CharT
|
iter_type
|
OutputIt
|
数据成员
| 成员 | 描述 |
std::locale::id
id
[静态]
|
facet 的标识符 |
成员函数
构造新的
num_put
facet
(公开成员函数) |
|
调用
do_put
(公开成员函数) |
受保护成员函数
析构
num_put
刻面
(受保护成员函数) |
|
|
[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
被保证接受任何满足
iostream组件实例化要求的
CharT
|
仅保证接受
char
,
wchar_t 及其他实现 定义的字符类型 |
| LWG 2392 | C++98 |
仅字符类型
CharT
可被
保证由
num_put
接受
|
可保证接受实现
定义的字符容器类型 |
参见
|
定义数值标点规则
(类模板) |
|
|
从输入字符序列解析数值
(类模板) |
|
|
(C++11)
|
将整型或浮点型数值转换为
string
(函数) |
|
(C++11)
|
将整型或浮点型数值转换为
wstring
(函数) |