std::chrono::zoned_time
| Определено в заголовочном файле <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 представляет собой логическую пару часового пояса и 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) |
представляет часовой пояс (класс) |