Espacios de nombres
Variantes
Acciones

std::chrono::zoned_time

De cppreference.com
< cpp‎ | chrono
 
 
Biblioteca de servicios
 
 
 
Definido en el archivo de encabezado <chrono>
template <

    class Duration,
    class TimeZonePtr = const std::chrono::time_zone*

> class zoned_time;
(desde C++20)
using zoned_seconds = std::chrono::zoned_time<std::chrono::seconds>;
(desde C++20)

La clase zoned_time (horario zonal) representa un emparejamiento lógico de una zona horaria y un std::chrono::time_point cuya resolución es Duration.

Una invariante de zoned_time es que siempre se refiere a una zona horaria válida y representa un punto de tiempo existente e inequívoco en esa zona horaria. De acuerdo con esta invariante, zoned_time no tiene un constructor de movimiento ni un operador de asignación de movimiento; los intentos de mover un zoned_time realizarán una copia.

El programa está mal formado si Duration no es una especialización de std::chrono::duration.

El parámetro de plantilla TimeZonePtr permite a los usuarios proporcionar sus propios tipos puntero de zona horaria y personalizar aún más el comportamiento de zoned_time a través de std::chrono::zoned_traits. No es necesario que los tipos de zona horaria personalizada admitan todas las operaciones admitidas por std::chrono::time_zone, solo aquellas utilizadas por las funciones realmente llamadas en zoned_time.

TimeZonePtr debe ser MoveConstructible. Los TimeZonePtr de solo movimiento están permitidos, pero son difíciles de usar, ya que zoned_time será inamovible y no es posible acceder a los TimeZonePtr almacenados.

Contenido

[editar] Tipos miembro

Tipo miembro Definición
duration std::common_type_t<Duration, std::chrono::seconds>

[editar] Funciones miembro

Construye un objeto zoned_time.
(función miembro pública) [editar]
Asigna un valor a un objeto zoned_time .
(función miembro pública) [editar]
Obtiene una copia del puntero a zona horaria.
(función miembro pública) [editar]
Obtiene el punto de tiempo almacenado como un objeto de tipo local_time.
(función miembro pública) [editar]
Obtiene el punto de tiempo almacenado como un objeto de tipo sys_time.
(función miembro pública) [editar]
Obtiene información sobre la zona horaria en el punto de tiempo almacenado.
(función miembro pública) [editar]

[editar] Funciones no miembro

Compara dos valores zoned_time.
(plantilla de función) [editar]
Emite un objeto zoned_time en un flujo.
(plantilla de función) [editar]

[editar] Clases auxiliares

Especialización de std::formatter que formatea un objeto zoned_time conforme al formato proporcionado.
(especialización de plantilla de clase) [editar]

[editar] Guías de deducción

[editar] Ejemplo

#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 {
            // puede lanzar si `location` no se encuentra
            // en la base de datos de zonas horarias
            const std::chrono::zoned_time zt{location, std::chrono::system_clock::now()};
            std::cout << std::setw(width) << location << " - Horario zonal: " << zt << '\n';
        } catch (std::chrono::nonexistent_local_time& ex) {
            std::cout << "Error: " << ex.what() << '\n';
        }
    }
}

Posible salida:

             Africa/Casablanca - Horario zonal: 2021-09-16 10:26:54.837665555 +01
America/Argentina/Buenos_Aires - Horario zonal: 2021-09-16 06:26:55.090150136 -03
              America/Barbados - Horario zonal: 2021-09-16 05:26:55.090419331 AST
    America/Indiana/Petersburg - Horario zonal: 2021-09-16 05:26:55.090465623 EDT
Error: America/Tarasco_Bar no se encuentra en la base de datos de zonas horarias
              Antarctica/Casey - Horario zonal: 2021-09-16 20:26:55.123070973 +11
             Antarctica/Vostok - Horario zonal: 2021-09-16 15:26:55.123151218 +06
                  Asia/Magadan - Horario zonal: 2021-09-16 20:26:55.123208852 +11
                   Asia/Manila - Horario zonal: 2021-09-16 17:26:55.123434512 PST
                 Asia/Shanghai - Horario zonal: 2021-09-16 17:26:55.123520538 CST
                    Asia/Tokyo - Horario zonal: 2021-09-16 18:26:55.123626199 JST
              Atlantic/Bermuda - Horario zonal: 2021-09-16 06:26:55.123713854 ADT
              Australia/Darwin - Horario zonal: 2021-09-16 18:56:55.155857464 ACST
            Europe/Isle_of_Man - Horario zonal: 2021-09-16 10:26:55.155909304 BST
Error: Europe/Laputa no se encuentra en la base de datos de zonas horarias
              Indian/Christmas - Horario zonal: 2021-09-16 16:26:55.215065303 +07
                  Indian/Cocos - Horario zonal: 2021-09-16 15:56:55.215137548 +0630
             Pacific/Galapagos - Horario zonal: 2021-09-16 03:26:55.215201447 -06