Condividi tramite


Struct sys_info

Fornisce un'interfaccia di basso livello per le informazioni sul fuso orario.

Sintassi

struct sys_info;

Osservazioni:

Fornisce un'interfaccia di basso livello alle informazioni sul fuso orario sul risultato della conversione di un sys_time oggetto in un oggetto local_time.

Membri

Funzione Descrizione
abbrev Abbreviazione utilizzata per l'oggetto associato time_zone e time_point.
begin, end Intervallo a cui offset e abbrev si applica per il fuso orario associato.
offset Offset UTC (Universal Time Coordinated) applicato per l'oggetto associato time_zone e time_point.
save Offset di regolazione dell'ora legale.

Membri non membri

Funzione Descrizione
operator<< Restituire un oggetto sys_info a un flusso.

abbrev

Abbreviazione utilizzata per l'oggetto associato time_zone e time_point.

string abbrev;

Valore restituito

Abbreviazione.

Osservazioni:

Le abbreviazioni non sono univoche tra le time_zone. Ciò significa che non è possibile mappare in modo affidabile le abbreviazioni a un time_zone offset UTC e .

begin, end

Fornisce l'intervallo rispetto al fuso orario associato, [begin, end), a cui offset e abbrev si applica.

sys_seconds begin;
sys_seconds end;

Valore restituito

Gli offset restituiti sys_seconds sono relativi all'oggetto associato time_point.

offset

Offset UTC in vigore per il fuso orario associato e time_point.

seconds offset;

Valore restituito

La relazione tra local_time e sys_time è : offset = local_time - sys_time.

save

Indica se l'oggetto è sull'ora sys_info legale e, in tal caso, suggerisce l'offset che questo fuso orario può usare se non si trattasse dell'ora legale.

minutes save;

Valore restituito

Se save != 0min, il fuso orario è in corrispondenza dell'ora legale all'oggetto associato time_point. In tal caso, offset-save suggerisce quale offset può time_zone usare se non all'ora legale.

Questo offset non è autorevole. Per ottenere un offset autorevole, confrontare con una query con il fuso orario usando un time_point oggetto che non cade durante l'ora legale. Ovvero, confrontare con un oggetto time_point che restituisce un save valore pari a zero.

Esempio: ottenere un sys_info

// compile using: /std:c++latest
#include <iostream>
#include <chrono>

using namespace std::chrono;

int main()
{
    sys_time<system_clock::duration> st = system_clock::now();
    
    const auto& timeZoneDatabase = get_tzdb();
    const auto& currentZone = timeZoneDatabase.current_zone();
    auto sysInfo = currentZone->get_info(st);

    std::cout << sysInfo << "\n";

    return 0;
}
begin: 2021-03-14 10:00:00, end: 2021-11-07 09:00:00, offset: -25200s, save: 60min, abbrev: PDT

Requisiti

Intestazione: <chrono>

Spazio dei nomi: std::chrono

Opzione del compilatore: /std:c++latest

<chrono>
file_clock class
high_resolution_clock
local_t Struct
system_clock Struct
Classe tai_clock
Classe utc_clock
Riferimento file di intestazione