Namespaces
Variants

std::chrono:: zoned_time

From cppreference.net
定义于头文件 <chrono>
template <

class Duration,
class TimeZonePtr = const std:: chrono :: time_zone *

> class zoned_time ;
(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

< chrono :: zoned_time < Duration, const chrono :: time_zone * >> = true ;
(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)
表示一个时区
(类)