Dal documentation:Perché le istanze di `java.time.ZoneOffset` sono ordinate 'all'indietro'?
Gli offset vengono confrontati nell'ordine in cui si verificano per la stessa ora del giorno in tutto il mondo. Pertanto, un offset di +10: 00 viene prima di un offset di +09: 00 e così via fino a -18: 00.
Qualcuno sa il motivo per cui sono ordinati in questo modo? Sembra contro-intuitivo in quanto è l'opposto dell'ordine del valore numerico dell'offset. È anche l'opposto dell'ordine in cui appariranno, leggendo da sinistra a destra, su una mappa centrata GMT/UTC + 0.
(A parte: non capisco perché la documentazione citata si riferisca a "fino a -18: 00" o -12: 00 o -24: 00 capisco Perchè -18: 00? Se stampare gli offset di tutti i fusi orari supportati di java.time.ZoneId
da -11: 00 a +12: 00.)
AGGIORNAMENTO: Una risposta a parte mia. Da altrove nella stessa documentazione:
Nel 2008, le correzioni di fuso orario in tutto il mondo sono passate da -12: 00 a +14: 00. Per evitare problemi di estensione di tale intervallo, pur continuando a fornire la convalida, l'intervallo di offset è limitato a -18: 00-18:00 inclusi.
Ovviamente, un altro modo per capire perché è "a ritroso" è che] la luce del giorno va "all'indietro" anche attraverso la mappa del mondo] (http://www.yellowpagesoftheworld.com/world/world-map.htm)! –
Risposta molto ben scritta. Aggiungerò un altro modo per pensarci: un nuovo giorno sorge prima verso est (rotazione terrestre). Ad esempio, i mercati azionari di Tokyo si aprono prima dei mercati di Londra, i mercati di Londra si aprono davanti ai mercati di New York che si aprono prima dei mercati di Chicago. Nello standard ISO 8601 utilizzato da java.time, utilizziamo un segno più per rappresentare le zone che sono in anticipo rispetto all'ora UTC (altri time-keeper hanno usato un segno meno, a proposito). Per quanto riguarda sinistra-a-destra, è così solo per le lingue da l a r e le mappe North-on-top. Metti il Sud in cima, o impara l'arabo, per leggere una mappa in ordine cronologico. –