Пространства имён
Варианты
Действия

std::chrono::zoned_time

Материал из cppreference.com
< cpp‎ | chrono
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования (C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
 
 
Определено в заголовочном файле <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 функция-элемент) [править]

[править] Функции, не являющиеся элементами

сравнивает два значения zoned_time
(шаблон функции) [править]
выводит 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)
представляет часовой пояс
(класс) [править]