std::chrono:: zoned_time
|
Definiert im Header
<chrono>
|
||
|
template
<
class
Duration,
|
(seit C++20) | |
|
using
zoned_seconds
=
std
::
chrono
::
zoned_time
<
std::
chrono
::
seconds
>
;
|
(seit C++20) | |
Die Klasse
zoned_time
repräsentiert eine logische Paarung einer Zeitzone und eines
std::chrono::time_point
, dessen Auflösung
Duration
ist.
Eine Invariante von
zoned_time
ist, dass sie sich immer auf eine gültige Zeitzone bezieht und einen existierenden und eindeutigen Zeitpunkt in dieser Zeitzone repräsentiert. Konsistent mit dieser Invariante besitzt
zoned_time
keinen Move-Konstruktor oder Move-Zuweisungsoperator; Versuche, eine
zoned_time
zu verschieben, führen eine Kopie durch.
Das Programm ist fehlerhaft, wenn
Duration
keine Spezialisierung von
std::chrono::duration
ist.
Der Template-Parameter
TimeZonePtr
ermöglicht Benutzern, ihre eigenen Zeitzonen-Zeigertypen bereitzustellen und das Verhalten von
zoned_time
weiter anzupassen über
std::chrono::zoned_traits
. Benutzerdefinierte Zeitzonentypen müssen nicht alle Operationen unterstützen, die von
std::chrono::time_zone
unterstützt werden, sondern nur diejenigen, die von den tatsächlich aufgerufenen Funktionen des
zoned_time
verwendet werden.
TimeZonePtr
muss
MoveConstructible
sein. Nur bewegliche
TimeZonePtr
s sind erlaubt, aber schwierig zu verwenden, da das
zoned_time
unbeweglich sein wird und es nicht möglich ist, auf die gespeicherte
TimeZonePtr
zuzugreifen.
Inhaltsverzeichnis |
Mitgliedertypen
| Mitgliedertyp | Definition |
duration
|
std:: common_type_t < Duration, std:: chrono :: seconds > |
Memberfunktionen
konstruiert einen
zoned_time
(öffentliche Elementfunktion) |
|
weist einem
zoned_time
einen Wert zu
(öffentliche Elementfunktion) |
|
|
erhält eine Kopie des Zeitzonenzeigers
(öffentliche Elementfunktion) |
|
erhält den gespeicherten Zeitpunkt als
local_time
(öffentliche Elementfunktion) |
|
erhält den gespeicherten Zeitpunkt als
sys_time
(öffentliche Elementfunktion) |
|
|
erhält Informationen über die Zeitzone zum gespeicherten Zeitpunkt
(öffentliche Elementfunktion) |
Nicht-Member-Funktionen
|
(C++20)
|
vergleicht zwei
zoned_time
-Werte
(Funktions-Template) |
|
(C++20)
|
gibt eine
zoned_time
in einen Stream aus
(Funktions-Template) |
Hilfsklassen
Formatierungsunterstützung für
zoned_time
(Klassen-Template-Spezialisierung) |
|
|
Hash-Unterstützung für
std::chrono::zoned_time
(Klassen-Template-Spezialisierung) |
Helfer-Spezialisierungen
|
template
<
class
Duration
>
constexpr
bool
enable_nonlocking_formatter_optimization
|
(seit C++23) | |
Diese Spezialisierung von
std::enable_nonlocking_formatter_optimization
ermöglicht eine effiziente Implementierung von
std::print
und
std::println
für die Ausgabe eines
chrono::zoned_time
-Objekts.
Deduktionshilfen
Beispiel
#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 { // kann eine Ausnahme werfen, wenn 'location' nicht in der Zeitzonendatenbank vorhanden ist 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'; } }
Mögliche Ausgabe:
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
Siehe auch
|
(C++20)
|
repräsentiert eine Zeitzone
(Klasse) |