- C 标准库
- C 标准库
- C++ 标准库
- C++ 库 - 首页
- C++ 库 - <fstream>
- C++ 库 - <iomanip>
- C++ 库 - <ios>
- C++ 库 - <iosfwd>
- C++ 库 - <iostream>
- C++ 库 - <istream>
- C++ 库 - <ostream>
- C++ 库 - <sstream>
- C++ 库 - <streambuf>
- C++ 库 - <atomic>
- C++ 库 - <complex>
- C++ 库 - <exception>
- C++ 库 - <functional>
- C++ 库 - <limits>
- C++ 库 - <locale>
- C++ 库 - <memory>
- C++ 库 - <new>
- C++ 库 - <numeric>
- C++ 库 - <regex>
- C++ 库 - <stdexcept>
- C++ 库 - <string>
- C++ 库 - <thread>
- C++ 库 - <tuple>
- C++ 库 - <typeinfo>
- C++ 库 - <utility>
- C++ 库 - <valarray>
- C++ STL 库
- C++ 库 - <array>
- C++ 库 - <bitset>
- C++ 库 - <deque>
- C++ 库 - <forward_list>
- C++ 库 - <list>
- C++ 库 - <map>
- C++ 库 - <multimap>
- C++ 库 - <queue>
- C++ 库 - <priority_queue>
- C++ 库 - <set>
- C++ 库 - <stack>
- C++ 库 - <unordered_map>
- C++ 库 - <unordered_set>
- C++ 库 - <vector>
- C++ 库 - <algorithm>
- C++ 库 - <iterator>
- C++ 高级库
- C++ 库 - <any>
- C++ 库 - <barrier>
- C++ 库 - <bit>
- C++ 库 - <chrono>
- C++ 库 - <cinttypes>
- C++ 库 - <clocale>
- C++ 库 - <condition_variable>
- C++ 库 - <coroutine>
- C++ 库 - <cstdlib>
- C++ 库 - <cstring>
- C++ 库 - <cuchar>
- C++ 库 - <charconv>
- C++ 库 - <cfenv>
- C++ 库 - <cmath>
- C++ 库 - <ccomplex>
- C++ 库 - <expected>
- C++ 库 - <format>
- C++ 库 - <future>
- C++ 库 - <flat_set>
- C++ 库 - <flat_map>
- C++ 库 - <filesystem>
- C++ 库 - <generator>
- C++ 库 - <initializer_list>
- C++ 库 - <latch>
- C++ 库 - <memory_resource>
- C++ 库 - <mutex>
- C++ 库 - <mdspan>
- C++ 库 - <optional>
- C++ 库 - <print>
- C++ 库 - <ratio>
- C++ 库 - <scoped_allocator>
- C++ 库 - <semaphore>
- C++ 库 - <source_location>
- C++ 库 - <span>
- C++ 库 - <spanstream>
- C++ 库 - <stacktrace>
- C++ 库 - <stop_token>
- C++ 库 - <syncstream>
- C++ 库 - <system_error>
- C++ 库 - <string_view>
- C++ 库 - <stdatomic>
- C++ 库 - <variant>
- C++ STL 库速查表
- C++ STL - 速查表
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; }