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 クラスは、タイムゾーンと解像度が Duration std::chrono::time_point の論理的な組み合わせを表現します。

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 でなければなりません。Move-onlyな TimeZonePtr は許可されますが、使用が困難です。なぜなら zoned_time は移動不可能となり、保存された TimeZonePtr にアクセスすることが不可能になるためです。

目次

メンバー型

メンバー型 定義
duration std:: common_type_t < Duration, std:: chrono :: seconds >

メンバー関数

zoned_time を構築する
(public member function)
zoned_time に値を代入する
(public member function)
タイムゾーンポインタのコピーを取得する
(public member function)
格納された時間点を local_time として取得する
(public member function)
格納された時間点を sys_time として取得する
(public member function)
格納された時間点におけるタイムゾーン情報を取得する
(public member function)

非メンバー関数

(C++20)
2つの 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 の効率的な実装を可能にし、 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
        {
            // '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)
タイムゾーンを表す
(クラス)