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
でなければなりません。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
|
(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)
|
タイムゾーンを表す
(クラス) |