std::chrono::zoned_time
Определено в заголовочном файле <chrono>
|
||
template < class Duration, |
(начиная с C++20) | |
using zoned_seconds = std::chrono::zoned_time<std::chrono::seconds>; |
(начиная с C++20) | |
Класс zoned_time
представляет собой логическую пару часового пояса и std::chrono::time_point, разрешение которого равно Duration
.
Инвариант zoned_time
заключается в том, что он всегда относится к действительному часовому поясу и представляет существующую и недвусмысленную точку времени в этом часовом поясе. В соответствии с этим инвариантом zoned_time
не имеет конструктора перемещения или оператора присваивания перемещением; попытки переместить zoned_time
приведут к копированию.
Программа некорректна, если Duration
не является специализацией std::chrono::duration.
Параметр шаблона TimeZonePtr
позволяет пользователям указывать собственные типы указателей часовых поясов и дополнительно настраивать поведение zoned_time
с помощью std::chrono::zoned_traits. Пользовательские типы часовых поясов не обязательно должны поддерживать все операции, поддерживаемые std::chrono::time_zone, а только те, которые используются функциями, фактически вызываемыми в zoned_time
.
TimeZonePtr
должен быть MoveConstructible. TimeZonePtr
предназначенные только для перемещения, разрешены, но их сложно использовать, так как zoned_time
будет неперемещаемым, а доступ к сохранённому TimeZonePtr
будет невозможен.
Содержание |
[править] Типы элементы
Тип элемент | Определение |
duration
|
std::common_type_t<Duration, std::chrono::seconds> |
[править] Функции-элементы
создаёт zoned_time (public функция-элемент) | |
присваивает значение zoned_time (public функция-элемент) | |
получает копию указателя часового пояса (public функция-элемент) | |
получает сохранённую точку времени как local_time (public функция-элемент) | |
получает сохранённую точку времени как sys_time (public функция-элемент) | |
получает информацию о часовом поясе в сохранённом моменте времени (public функция-элемент) |
[править] Функции, не являющиеся элементами
(C++20) |
сравнивает два значения zoned_time (шаблон функции) |
(C++20) |
выводит zoned_time в поток (шаблон функции) |
[править] Вспомогательные классы
поддержка форматирования для zoned_time (специализация шаблона класса) | |
поддержка хэширования для std::chrono::zoned_time (специализация шаблона класса) |
[править] Правила вывода
[править] Пример
#include <chrono> #include <iomanip> #include <iostream> #include <algorithm> #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 - Время Часового Пояса: 2021-09-16 10:26:54.837665555 +01 America/Argentina/Buenos_Aires - Время Часового Пояса: 2021-09-16 06:26:55.090150136 -03 America/Barbados - Время Часового Пояса: 2021-09-16 05:26:55.090419331 AST America/Indiana/Petersburg - Время Часового Пояса: 2021-09-16 05:26:55.090465623 EDT Ошибка: America/Tarasco_Bar not found in timezone database Antarctica/Casey - Время Часового Пояса: 2021-09-16 20:26:55.123070973 +11 Antarctica/Vostok - Время Часового Пояса: 2021-09-16 15:26:55.123151218 +06 Asia/Magadan - Время Часового Пояса: 2021-09-16 20:26:55.123208852 +11 Asia/Manila - Время Часового Пояса: 2021-09-16 17:26:55.123434512 PST Asia/Shanghai - Время Часового Пояса: 2021-09-16 17:26:55.123520538 CST Asia/Tokyo - Время Часового Пояса: 2021-09-16 18:26:55.123626199 JST Atlantic/Bermuda - Время Часового Пояса: 2021-09-16 06:26:55.123713854 ADT Australia/Darwin - Время Часового Пояса: 2021-09-16 18:56:55.155857464 ACST Europe/Isle_of_Man - Время Часового Пояса: 2021-09-16 10:26:55.155909304 BST Ошибка: Europe/Laputa not found in timezone database Indian/Christmas - Время Часового Пояса: 2021-09-16 16:26:55.215065303 +07 Indian/Cocos - Время Часового Пояса: 2021-09-16 15:56:55.215137548 +0630 Pacific/Galapagos - Время Часового Пояса: 2021-09-16 03:26:55.215201447 -06
[править] Смотрите также
(C++20) |
представляет часовой пояс (класс) |