名前空間
変種
操作

std::chrono::zoned_time

From cppreference.com
< cpp‎ | chrono
 
 
 
 
ヘッダー <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を移動しようとすると、コピーが実行されます。

Durationstd::chrono::durationの特殊化でない場合、プログラムは不正形式となります。

テンプレートパラメータTimeZonePtrを使用すると、ユーザーは独自のタイムゾーンポインタ型を提供し、std::chrono::zoned_traitsを介してzoned_timeの動作をさらにカスタマイズできます。カスタムタイムゾーン型は、std::chrono::time_zoneでサポートされているすべての操作をサポートする必要はありません。zoned_timeで実際に呼び出される関数によって使用される操作のみをサポートすれば十分です。

TimeZonePtrMoveConstructibleである必要があります。ムーブ専用の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) [編集]

[編集] 非メンバ関数

2つのzoned_time値を比較します
(function template) [編集]
zoned_timeをストリームに出力します
(function template) [編集]

[編集] ヘルパークラス

zoned_time の書式設定サポート
(クラス テンプレートの特殊化) [edit]
std::chrono::zoned_time のハッシュサポート
(クラステンプレートの特殊化)

[編集] ヘルパー特殊化

template< class Duration >

constexpr bool enable_nonlocking_formatter_optimization

  <chrono::zoned_time<Duration, const chrono::time_zone*>> = true;
(C++23から)

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
        {
            // 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)
タイムゾーンを表す
(クラス) [編集]
English 日本語 中文(简体) 中文(繁體)