命名空间
变体
操作

std::chrono::zoned_time

来自 cppreference.com
< cpp‎ | chrono
 
 
工具库
语言支持
类型支持 (基本类型、RTTI)
库功能测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
可变参数函数
调试支持
(C++26)
三方比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中已弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型操作
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
通用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
基本字符串转换
(C++17)
(C++17)

 
 
 
定义在头文件 <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 必须是 MoveConstructible。只允许移动的 TimeZonePtr,但很难使用,因为 zoned_time 将不可移动,并且无法访问存储的 TimeZonePtr

内容

[编辑] 成员类型

成员类型 定义
duration std::common_type_t<Duration, std::chrono::seconds>

[编辑] 成员函数

构造一个 zoned_time
(公共成员函数) [编辑]
将值赋给一个 zoned_time
(公共成员函数) [编辑]
获取时区指针的副本
(公共成员函数) [编辑]
将存储的时间点作为 local_time 获取
(公共成员函数) [编辑]
将存储的时间点作为 sys_time 获取
(公共成员函数) [编辑]
获取存储时间点时区的信息
(公共成员函数) [编辑]

[编辑] 非成员函数

比较两个 zoned_time
(函数模板) [编辑]
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 特化允许对 std::printstd::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)
代表时区
(类) [编辑]