std::time_put
来自cppreference.com
                    
                                        
                    
                    
                                                            
                    |   定义于头文件  <locale>
  | 
||
|   template<      class CharT,   | 
||
类模板 std::time_put 封装日期和时间格式化规则。 I/O 操纵符 std::put_time 用 I/O 流的 locale 的 std::time_put 平面生成 std::tm 对象的文本表示。
继承图
类型要求
 -OutputIt 必须满足遗留输出迭代器 (LegacyOutputIterator)  的要求。
 | 
特化
标准库提供二个(独立于本地环境)的全特化和二个部分特化:
|   定义于头文件  
<locale>  | |
| std::time_put<char> | 创建日期和时间的窄字符串表示 | 
| std::time_put<wchar_t> | 创建日期和时间的宽字符串表示 | 
| std::time_put<char, OutputIt> | 用定制输出迭代器创建日期和时间的窄字符串表示 | 
| std::time_put<wchar_t, OutputIt> | 用定制输出迭代器创建日期和时间的宽字符串表示 | 
另外, C++ 程序中构造的每个 locale 对象都实装这些特化的其自身(本地环境限定)版本。
成员类型
| 成员类型 | 定义 | 
  char_type
 | 
  CharT
 | 
  iter_type
 | 
  OutputIt
 | 
成员函数
|   构造新的 time_put 平面  (公开成员函数)  | |
|   析构 time_put 平面  (受保护成员函数)  | |
  调用 do_put (公开成员函数)  | 
成员对象
|    static std::locale::id id  | 
  locale 的 id  (公开成员对象)  | 
受保护成员函数
|    [虚]  | 
  格式化日期/时间并写入输出流  (虚受保护成员函数)  | 
示例
运行此代码
#include <iostream> #include <ctime> #include <iomanip> #include <codecvt> int main() { std::time_t t = std::time(NULL); std::wbuffer_convert<std::codecvt_utf8<wchar_t>> conv(std::cout.rdbuf()); std::wostream out(&conv); out.imbue(std::locale("ja_JP.utf8")); // 此 I/O 操纵符 std::put_time 使用 std::time_put<wchar_t> out << std::put_time(std::localtime(&t), L"%A %c") << '\n'; }
输出:
水曜日 2011年11月09日 12時32分05秒
参阅
|   表示系统提供的具名本地环境的 std::time_put  (类模板)  | |
|   从输入字符序列中解析时间/日期值到 std::tm 中  (类模板)  | |
|    (C++11)  | 
  按照指定格式格式化并输出日期/时间值  (函数模板)  |