std::chrono:: zoned_time
|
Definido en el 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
representa un emparejamiento lógico de una zona horaria y un
std::chrono::time_point
cuya resolución es
Duration
.
Un invariante de
zoned_time
es que siempre se refiere a una zona horaria válida y representa un punto temporal existente y no ambiguo en esa zona horaria. Consistente con este invariante,
zoned_time
no tiene constructor de movimiento ni 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 de puntero de zona horaria y personalizar aún más el comportamiento de
zoned_time
mediante
std::chrono::zoned_traits
. Los tipos de zona horaria personalizados no necesitan soportar todas las operaciones compatibles con
std::chrono::time_zone
, solo aquellas utilizadas por las funciones realmente llamadas en el
zoned_time
.
TimeZonePtr
debe ser
MoveConstructible
. Los
TimeZonePtr
de solo movimiento están permitidos pero son difíciles de usar, ya que el
zoned_time
será inamovible y no será posible acceder al
TimeZonePtr
almacenado.
Contenidos |
Tipos de miembros
| Tipo de miembro | Definición |
duration
|
std:: common_type_t < Duration, std:: chrono :: seconds > |
Funciones miembro
construye un
zoned_time
(función miembro pública) |
|
asigna un valor a un
zoned_time
(función miembro pública) |
|
|
obtiene una copia del puntero de zona horaria
(función miembro pública) |
|
obtiene el punto de tiempo almacenado como un
local_time
(función miembro pública) |
|
obtiene el punto de tiempo almacenado como un
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) |
Funciones no miembro
|
(C++20)
|
compara dos valores de
zoned_time
(plantilla de función) |
|
(C++20)
|
envía un
zoned_time
a un flujo
(plantilla de función) |
Clases auxiliares
soporte de formato para
zoned_time
(especialización de plantilla de clase) |
|
|
soporte de hash para
std::chrono::zoned_time
(especialización de plantilla de clase) |
Especializaciones auxiliares
|
template
<
class
Duration
>
constexpr
bool
enable_nonlocking_formatter_optimization
|
(desde C++23) | |
Esta especialización de
std::enable_nonlocking_formatter_optimization
permite una implementación eficiente de
std::print
y
std::println
para imprimir un objeto
chrono::zoned_time
.
Guías de deducción
Ejemplo
#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 { // puede lanzar una excepción si 'location' no está 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 << " - Tiempo Zonificado: " << zt << '\n'; } catch (std::runtime_error& ex) { std::cout << "Error: " << ex.what() << '\n'; } }
Salida posible:
Africa/Casablanca - Tiempo Zonificado: 2023-06-29 20:58:34.697449319 +01
America/Argentina/Buenos_Aires - Tiempo Zonificado: 2023-06-29 16:58:34.709957354 -03
America/Barbados - Tiempo Zonificado: 2023-06-29 15:58:34.709977888 AST
America/Indiana/Petersburg - Tiempo Zonificado: 2023-06-29 15:58:34.709998072 EDT
Error: tzdb: no se puede localizar la zona: America/Tarasco_Bar
Antarctica/Casey - Tiempo Zonificado: 2023-06-30 06:58:34.710093685 +11
Antarctica/Vostok - Tiempo Zonificado: 2023-06-30 01:58:34.710107932 +06
Asia/Magadan - Tiempo Zonificado: 2023-06-30 06:58:34.710121831 +11
Asia/Manila - Tiempo Zonificado: 2023-06-30 03:58:34.710134751 PST
Asia/Shanghai - Tiempo Zonificado: 2023-06-30 03:58:34.710153259 CST
Asia/Tokyo - Tiempo Zonificado: 2023-06-30 04:58:34.710172815 JST
Atlantic/Bermuda - Tiempo Zonificado: 2023-06-29 16:58:34.710191043 ADT
Australia/Darwin - Tiempo Zonificado: 2023-06-30 05:28:34.710236720 ACST
Europe/Isle_of_Man - Tiempo Zonificado: 2023-06-29 20:58:34.710256834 BST
Error: tzdb: no se puede localizar la zona: Europe/Laputa
Indian/Christmas - Tiempo Zonificado: 2023-06-30 02:58:34.710360409 +07
Indian/Cocos - Tiempo Zonificado: 2023-06-30 02:28:34.710377520 +0630
Pacific/Galapagos - Tiempo Zonificado: 2023-06-29 13:58:34.710389952 -06
Véase también
|
(C++20)
|
representa una zona horaria
(clase) |