C++ iomanip 库 - put_time 函数



描述

此函数首先构造一个 basic_ostream::sentry 类型的对象来访问输出序列。然后(如果评估哨兵对象为真),它调用 time_put::put(使用流的选定区域设置)来执行格式化和插入操作,并相应地调整流的内部状态标志。最后,在返回之前销毁哨兵对象。

它用于插入 tmb 指向的日期和时间信息的表示形式,并根据参数 fmt 指定的格式进行格式化。

声明

以下是 std::put_time 函数的声明。

template <class charT>
/*unspecified*/ put_time (const struct tm* tmb, const charT* fmt);

参数

tmb − 指向 struct tm 类型对象的指针,其中包含要格式化的日期和时间信息。struct tm 是在 <ctime> 头文件中定义的类。

fmt − time_put::put 用作格式字符串的 C 字符串。它包含任意组合的常规字符和特殊格式说明符。这些格式说明符由函数替换为相应的数值,以表示 tmb 中指定的时间。

它们都以百分号 (%) 开头,如下所示:

说明符 替换为 示例
%a 缩写工作日名称* Thu
%A 完整工作日名称* Thursday
%b 缩写月份名称* Aug
%B 完整月份名称* August
%c 日期和时间表示* Thu Aug 23 14:55:02 2001
%C 年份除以 100 并截断为整数 (00-99) 20
%d 月份中的日期,零填充 (01-31) 23
%D 简短的 MM/DD/YY 日期,相当于 %m/%d/%y 08/23/01
%e 月份中的日期,空格填充 ( 1-31) 23
%F 简短的 YYYY-MM-DD 日期,相当于 %Y-%m-%d 2001-08-23
%g 基于周的年份,最后两位数字 (00-99) 01
%G 基于周的年份 2001
%h 缩写月份名称* (与 %b 相同) Aug
%H 24 小时制小时 (00-23) 14
%I 12 小时制小时 (01-12) 02
%j 一年中的日期 (001-366) 235
%m 月份作为十进制数 (01-12) 08
%M 分钟 (00-59) 55
%n 换行符 ('\n')
%p AM 或 PM 表示 PM
%r 12 小时制时间* 02:55:02 pm
%R 24 小时制 HH:MM 时间,相当于 %H:%M 14:55
%S 秒 (00-61) 02
%t 水平制表符 ('\t')
%T ISO 8601 时间格式 (HH:MM:SS),相当于 %H:%M:%S 14:55:02
%u ISO 8601 工作日,星期一为 1 (1-7) 4
%U 以第一个星期日为第一周的第一天计算的周数 (00-53) 33
%V ISO 8601 周数 (00-53) 34
%w 工作日,以星期日为 0 (0-6) 4
%W 以第一个星期一为第一周的第一天计算的周数 (00-53) 34
%x 日期表示* 08/23/01
%X 时间表示* 14:55:02
%y 年份,最后两位数字 (00-99) 01
%Y 年份 2001
%z

ISO 8601 时区相对于 UTC 的偏移量 (1 分钟 = 1,1 小时 = 100)

如果无法确定时区,则无字符

+100
%Z

时区名称或缩写*

如果无法确定时区,则无字符

CDT
%% 百分号 (%) %

返回值

未指定。此函数应仅用作流操作符。

错误通过修改流的内部状态标志来发出信号:

标志 错误
eofbit -
failbit 函数未能按 fmt 指定的格式化 tmb(如果 sentry 的构造失败,也可能设置此标志)。
badbit

流上的插入失败,或发生其他错误(例如,当此函数捕获内部操作抛出的异常时)。

设置后,流的完整性可能受到影响。

异常

基本保证 − 如果抛出异常,则对象处于有效状态。

如果结果错误状态标志不是 goodbit,并且成员异常被设置为为此状态抛出,则它会抛出一个成员类型为 failure 的异常。

内部操作抛出的任何异常都会被函数捕获并处理,并设置 badbit。如果在上次调用 exceptions 时设置了 badbit,则该函数会重新抛出捕获的异常。

数据竞争

访问 tmb 指向的对象和 fmt 指向的数组。

修改插入它的流对象。

对同一流对象的并发访问可能会导致数据竞争,除非标准流对象 (cout、cerr、clog、wcout、wcerr 和 wclog) 与 stdio 同步(在这种情况下,不会启动数据竞争,尽管不保证来自多个线程的字符的插入顺序)。

示例

下面的例子解释了 put_time 函数。

#include <iostream>
#include <iomanip>
#include <ctime>
#include <chrono>

int main () {
   using std::chrono::system_clock;
   std::time_t tt = system_clock::to_time_t (system_clock::now());

   struct std::tm * ptm = std::localtime(&tt);
   std::cout << "Now (local time): " << std::put_time(ptm,"%c") << '\n';

   return 0;
}
iomanip.htm
广告