std::chrono::zoned_time
| ヘッダー <chrono> で定義 |
||
| template< class Duration, |
(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である必要があります。ムーブ専用の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値を比較します(function template) |
| (C++20) |
zoned_timeをストリームに出力します(function template) |
[編集] ヘルパークラス
zoned_time の書式設定サポート(クラス テンプレートの特殊化) | |
| std::chrono::zoned_time のハッシュサポート (クラステンプレートの特殊化) |
[編集] ヘルパー特殊化
| template< class Duration > constexpr bool enable_nonlocking_formatter_optimization |
(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) |
タイムゾーンを表す (クラス) |