std::chrono:: zoned_time
|
定义于头文件
<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
必须满足
可移动构造
要求。仅支持移动语义的
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
的特化实现了针对
chrono::zoned_time
对象的高效
std::print
与
std::println
输出功能。
推导指引
示例
#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 { // 如果'location'不在时区数据库中可能抛出异常 const std::chrono::zoned_time zt{location, std::chrono::system_clock::now()}; std::cout << std::setw(width) << location << " - 时区时间: " << zt << '\n'; } catch (std::runtime_error& ex) { std::cout << "错误: " << ex.what() << '\n'; } }
可能的输出:
Africa/Casablanca - 时区时间: 2023-06-29 20:58:34.697449319 +01
America/Argentina/Buenos_Aires - 时区时间: 2023-06-29 16:58:34.709957354 -03
America/Barbados - 时区时间: 2023-06-29 15:58:34.709977888 AST
America/Indiana/Petersburg - 时区时间: 2023-06-29 15:58:34.709998072 EDT
错误: tzdb: cannot locate zone: America/Tarasco_Bar
Antarctica/Casey - 时区时间: 2023-06-30 06:58:34.710093685 +11
Antarctica/Vostok - 时区时间: 2023-06-30 01:58:34.710107932 +06
Asia/Magadan - 时区时间: 2023-06-30 06:58:34.710121831 +11
Asia/Manila - 时区时间: 2023-06-30 03:58:34.710134751 PST
Asia/Shanghai - 时区时间: 2023-06-30 03:58:34.710153259 CST
Asia/Tokyo - 时区时间: 2023-06-30 04:58:34.710172815 JST
Atlantic/Bermuda - 时区时间: 2023-06-29 16:58:34.710191043 ADT
Australia/Darwin - 时区时间: 2023-06-30 05:28:34.710236720 ACST
Europe/Isle_of_Man - 时区时间: 2023-06-29 20:58:34.710256834 BST
错误: tzdb: cannot locate zone: Europe/Laputa
Indian/Christmas - 时区时间: 2023-06-30 02:58:34.710360409 +07
Indian/Cocos - 时区时间: 2023-06-30 02:28:34.710377520 +0630
Pacific/Galapagos - 时区时间: 2023-06-29 13:58:34.710389952 -06
参见
|
(C++20)
|
表示一个时区
(类) |