std::chrono::zoned_time
Definido en el archivo de encabezado <chrono>
|
||
template < class Duration, |
(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) | |
Asigna un valor a un objeto zoned_time . (función miembro pública) | |
Obtiene una copia del puntero a zona horaria. (función miembro pública) | |
Obtiene el punto de tiempo almacenado como un objeto de tipo local_time . (función miembro pública) | |
Obtiene el punto de tiempo almacenado como un objeto de tipo sys_time . (función miembro pública) | |
Obtiene información sobre la zona horaria en el punto de tiempo almacenado. (función miembro pública) |
[editar] Funciones no miembro
(C++20) |
Compara dos valores zoned_time . (plantilla de función) |
(C++20) |
Emite un objeto zoned_time en un flujo. (plantilla de función) |
[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] 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