我试图计算两者之间的差异LocalDateTime。
LocalDateTime
输出必须为格式y years m months d days h hours m minutes s seconds。这是我写的:
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 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 25 days -1 hours -5 minutes -10 seconds.
从这个链接应该是29 years 8 months 24 days 22 hours, 54 minutes and 50 seconds。因此该算法也需要处理负数。
29 years 8 months 24 days 22 hours, 54 minutes and 50 seconds
注意问题不是关于哪个站点给我什么结果,我需要知道正确的算法并且需要正确的结果。
不幸的是,似乎也没有跨时间的周期类,因此你可能必须自己进行计算。
幸运的是,日期和时间类具有许多实用程序方法,可以在某种程度上简化此过程。这是一种计算差异的方法,尽管不一定最快:
LocalDateTime fromDateTime = LocalDateTime.of(1984, 12, 16, 7, 45, 55); LocalDateTime toDateTime = LocalDateTime.of(2014, 9, 10, 6, 40, 45); LocalDateTime tempDateTime = LocalDateTime.from( fromDateTime ); long years = tempDateTime.until( toDateTime, ChronoUnit.YEARS ); tempDateTime = tempDateTime.plusYears( years ); long months = tempDateTime.until( toDateTime, ChronoUnit.MONTHS ); tempDateTime = tempDateTime.plusMonths( months ); long days = tempDateTime.until( toDateTime, ChronoUnit.DAYS ); tempDateTime = tempDateTime.plusDays( days ); long hours = tempDateTime.until( toDateTime, ChronoUnit.HOURS ); tempDateTime = tempDateTime.plusHours( hours ); long minutes = tempDateTime.until( toDateTime, ChronoUnit.MINUTES ); tempDateTime = tempDateTime.plusMinutes( minutes ); long seconds = tempDateTime.until( toDateTime, ChronoUnit.SECONDS ); System.out.println( years + " years " + months + " months " + days + " days " + hours + " hours " + minutes + " minutes " + seconds + " seconds."); //prints: 29 years 8 months 24 days 22 hours 54 minutes 50 seconds.
基本思想是:创建一个临时的开始日期并获得整年的结束时间。然后,根据年数调整该日期,以使开始日期小于结束日期。对每个时间单位以降序重复该操作。
最后免责声明:我没有考虑不同的时区(两个日期都应该在同一时区中),也没有测试/检查夏令时或日历中的其他更改(例如萨摩亚中的时区更改)影响此计算。因此,请谨慎使用。
我发现最好的方法是使用ChronoUnit。
long minutes = ChronoUnit.MINUTES.between(fromDate, toDate); long hours = ChronoUnit.HOURS.between(fromDate, toDate);
其他文档在这里:https : //docs.oracle.com/javase/tutorial/datetime/iso/period.html