Namespaces
Variants

std::chrono:: zoned_time

From cppreference.net
Определено в заголовочном файле <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
(публичная функция-член)
присваивает значение 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

< chrono :: zoned_time < Duration, const chrono :: time_zone * >> = true ;
(начиная с 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)
представляет часовой пояс
(класс)