Я пытаюсь вычислить разницу между двумя LocalDateTime
.
Вывод должен быть в формате y years m months d days h hours m minutes s seconds
. Вот что я написал:
import java.time.Duration;
import java.time.Instant;
import java.time.LocalDateTime;
import java.time.Period;
import java.time.ZoneId;
public class Main {
static final int MINUTES_PER_HOUR = 60;
static final int SECONDS_PER_MINUTE = 60;
static final int SECONDS_PER_HOUR = SECONDS_PER_MINUTE * MINUTES_PER_HOUR;
public static void main(String[] args) {
LocalDateTime toDateTime = LocalDateTime.of(2014, 9, 9, 19, 46, 45);
LocalDateTime fromDateTime = LocalDateTime.of(1984, 12, 16, 7, 45, 55);
Period period = getPeriod(fromDateTime, toDateTime);
long time[] = getTime(fromDateTime, toDateTime);
System.out.println(period.getYears() + " years " +
period.getMonths() + " months " +
period.getDays() + " days " +
time[0] + " hours " +
time[1] + " minutes " +
time[2] + " seconds.");
}
private static Period getPeriod(LocalDateTime dob, LocalDateTime now) {
return Period.between(dob.toLocalDate(), now.toLocalDate());
}
private static long[] getTime(LocalDateTime dob, LocalDateTime now) {
LocalDateTime today = LocalDateTime.of(now.getYear(),
now.getMonthValue(), now.getDayOfMonth(), dob.getHour(), dob.getMinute(), dob.getSecond());
Duration duration = Duration.between(today, now);
long seconds = duration.getSeconds();
long hours = seconds / SECONDS_PER_HOUR;
long minutes = ((seconds % SECONDS_PER_HOUR) / SECONDS_PER_MINUTE);
long secs = (seconds % SECONDS_PER_MINUTE);
return new long[]{hours, minutes, secs};
}
}
Вывод, который я получаю 29 years 8 months 24 days 12 hours 0 minutes 50 seconds
. Я проверил свой результат с этого сайта (со значениями 12/16/1984 07:45:55
и 09/09/2014 19:46:45
). Следующий скриншот показывает результат:
Я вполне уверен, что поля после значения месяца неправильно в моем коде. Любое предложение будет очень полезным.
Обновить
Я проверил свой результат с другого сайта, и полученный результат отличается. Вот оно: Рассчитайте продолжительность между двумя датами (результат: 29 лет, 8 месяцев, 24 дня, 12 часов, 0 минут и 50 секунд).
Обновить
Поскольку я получил два разных результата с двух разных сайтов, мне интересно, является ли алгоритм моих расчетов законным или нет. Если я использую следующие два LocalDateTime
объекта:
LocalDateTime toDateTime = LocalDateTime.of(2014, 9, 10, 6, 40, 45);
LocalDateTime fromDateTime = LocalDateTime.of(1984, 12, 16, 7, 45, 55);
Тогда выходной: 29 years 8 months 25 days -1 hours -5 minutes -10 seconds.
По этой ссылке так и должно быть 29 years 8 months 24 days 22 hours, 54 minutes and 50 seconds
. Поэтому алгоритм должен обрабатывать и отрицательные числа.
Обратите внимание, что вопрос не в том, какой сайт дал мне какой результат, мне нужно знать правильный алгоритм и иметь правильные результаты.
7:45:55
и время окончания 19:46:45
(или 7:46:45
PM). Таким образом, разница между этими двумя значениями составляет 12 часов, 0 минут и 50 секунд, а не 23 часа, 34 минуты и 12 секунд. Таким образом, ваш фактический расчет кажется верным, по крайней мере, в части времени.
LocalDateTime
нет часового пояса, не может быть уникального ответа. Даже если вы предполагаете, что начальный и конечный часовые пояса совпадают, в некоторых зонах даты, такие как 2014-09-09, будут в летнее или летнее время, а в других - нет. Это может скинуть вещи на час. Таким образом, вычисление разницы со вторым не имеет смысла, если это не разрешено.
LocalDateTime
дает нереальные результаты, поскольку в этом классе намеренно отсутствует какое-либо понятие о часовом поясе или смещении от UTC? Для реальных значений, назначить временную зону с помощью ZoneId
для использования ZonedDateTime
.
Period.between()
применить округление?