std::chrono::zoned_time
来自 cppreference.com
定义在头文件 <chrono> 中 |
||
template< class Duration, |
(自 C++20 起) | |
using zoned_seconds = std::chrono::zoned_time<std::chrono::seconds>; |
(自 C++20 起) | |
类 zoned_time
表示时区和 std::chrono::time_point 的逻辑配对,其分辨率为 Duration
。
zoned_time
的一个不变式是它始终引用一个有效的时区,并表示该时区中存在的且不含糊的时间点。与该不变式一致,zoned_time
没有移动构造函数或移动赋值运算符;尝试移动 zoned_time
将执行复制操作。
如果 Duration
不是 std::chrono::duration 的特化,则程序格式错误。
模板参数 TimeZonePtr
允许用户提供自己的时区指针类型,并通过 std::chrono::zoned_traits 进一步自定义 zoned_time
的行为。自定义时区类型不必支持 std::chrono::time_zone 支持的所有操作,而只支持实际上在 zoned_time
上调用的函数使用的那些操作。
TimeZonePtr
必须是 MoveConstructible。只允许移动的 TimeZonePtr
,但很难使用,因为 zoned_time
将不可移动,并且无法访问存储的 TimeZonePtr
。
内容 |
[编辑] 成员类型
成员类型 | 定义 |
duration
|
std::common_type_t<Duration, std::chrono::seconds> |
[编辑] 成员函数
构造一个 zoned_time (公共成员函数) | |
将值赋给一个 zoned_time (公共成员函数) | |
获取时区指针的副本 (公共成员函数) | |
将存储的时间点作为 local_time 获取(公共成员函数) | |
将存储的时间点作为 sys_time 获取(公共成员函数) | |
获取存储时间点时区的信息 (公共成员函数) |
[编辑] 非成员函数
(C++20) |
比较两个 zoned_time 值(函数模板) |
(C++20) |
将 zoned_time 输出到流中(函数模板) |
[编辑] 辅助类
zoned_time 的格式化支持(类模板特化) | |
对 std::chrono::zoned_time 的哈希支持 (类模板特化) |
[编辑] 辅助特化
template< class Duration > constexpr bool enable_nonlocking_formatter_optimization |
(自 C++23) | |
此 std::enable_nonlocking_formatter_optimization 特化允许对 std::print 和 std::println 进行有效实现,用于打印 chrono::zoned_time
对象。
[编辑] 推导指南
[编辑] 示例
运行此代码
#include <algorithm> #include <chrono> #include <iomanip> #include <iostream> #include <stdexcept> #include <string_view> int main() { constexpr std::string_view locations[] = { "Africa/Casablanca", "America/Argentina/Buenos_Aires", "America/Barbados", "America/Indiana/Petersburg", "America/Tarasco_Bar", "Antarctica/Casey", "Antarctica/Vostok", "Asia/Magadan", "Asia/Manila", "Asia/Shanghai", "Asia/Tokyo", "Atlantic/Bermuda", "Australia/Darwin", "Europe/Isle_of_Man", "Europe/Laputa", "Indian/Christmas", "Indian/Cocos", "Pacific/Galapagos", }; constexpr auto width = std::ranges::max_element(locations, {}, [](const auto& s){ return s.length(); })->length(); for (const auto location : locations) try { // may throw if 'location' is not in the time zone database const std::chrono::zoned_time zt{location, std::chrono::system_clock::now()}; std::cout << std::setw(width) << location << " - Zoned Time: " << zt << '\n'; } catch (std::runtime_error& ex) { std::cout << "Error: " << ex.what() << '\n'; } }
可能的输出
Africa/Casablanca - Zoned Time: 2023-06-29 20:58:34.697449319 +01 America/Argentina/Buenos_Aires - Zoned Time: 2023-06-29 16:58:34.709957354 -03 America/Barbados - Zoned Time: 2023-06-29 15:58:34.709977888 AST America/Indiana/Petersburg - Zoned Time: 2023-06-29 15:58:34.709998072 EDT Error: tzdb: cannot locate zone: America/Tarasco_Bar Antarctica/Casey - Zoned Time: 2023-06-30 06:58:34.710093685 +11 Antarctica/Vostok - Zoned Time: 2023-06-30 01:58:34.710107932 +06 Asia/Magadan - Zoned Time: 2023-06-30 06:58:34.710121831 +11 Asia/Manila - Zoned Time: 2023-06-30 03:58:34.710134751 PST Asia/Shanghai - Zoned Time: 2023-06-30 03:58:34.710153259 CST Asia/Tokyo - Zoned Time: 2023-06-30 04:58:34.710172815 JST Atlantic/Bermuda - Zoned Time: 2023-06-29 16:58:34.710191043 ADT Australia/Darwin - Zoned Time: 2023-06-30 05:28:34.710236720 ACST Europe/Isle_of_Man - Zoned Time: 2023-06-29 20:58:34.710256834 BST Error: tzdb: cannot locate zone: Europe/Laputa Indian/Christmas - Zoned Time: 2023-06-30 02:58:34.710360409 +07 Indian/Cocos - Zoned Time: 2023-06-30 02:28:34.710377520 +0630 Pacific/Galapagos - Zoned Time: 2023-06-29 13:58:34.710389952 -06
[编辑] 另请参见
(C++20) |
代表时区 (类) |