我正在尝试计算两者之间的差异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()
四舍五入吗?