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
(публичная функция-член) |
|
присваивает значение
zoned_time
(публичная функция-член) |
|
|
получает копию указателя на часовой пояс
(публичная функция-член) |
|
получает сохраненную точку времени как
local_time
(публичная функция-член) |
|
получает сохраненную точку времени как
sys_time
(публичная функция-член) |
|
|
получает информацию о часовом поясе в сохраненной точке времени
(публичная функция-член) |
Функции, не являющиеся членами класса
|
(C++20)
|
сравнивает два значения
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)
|
представляет часовой пояс
(класс) |