gpt4 book ai didi

android - JodaTime 期间返回意外结果

转载 作者:行者123 更新时间:2023-12-04 16:47:00 25 4
gpt4 key购买 nike

我正在尝试计算 Android 应用程序中任意两个给定时间之间的差异。为完成此任务,我使用了 JodaTime 和 Period 类以及 Period 的 getYears()、getDays()、getHours()、getMinutes() 和 getSeconds() 方法。但是,我意识到它给出了日期中每个元素之间的绝对差异。例如,在日期 2017-01-29 00:00:00 (yyyy-MM-dd HH:mm:ss)2018-01-28 00:00 调用我的函数:00 将返回:

0 years
2 days
0 hours
0 minutes
0 seconds

什么时候应该返回 364 天 以及其他所有部分的零。当然,这是一个 Android 应用程序,所以我没有打印它们,我单独处理显示。我可以使用 LocalDateTime 和 Duration.between 在我的计算机上执行此操作,但我不能在此处使用这些类。我正在寻找针对我当前方法(如下所示)的修复程序或针对全新方法的建议。先感谢您。我当前的功能:

public int[] getDifference(DateTime start, DateTime end){
Period p = new Period(start, end);
int[] differences = new int[5];
differences[0] = p.getYears();
differences[1] = p.getDays();
differences[2] = p.getHours();
differences[3] = p.getMinutes();
differences[4] = p.getSeconds();
return differences;
}

最佳答案

为什么您期望 364 天?阅读 class doc for Period .

public int getDays()

Gets the days field part of the period.

“字段部分”是这里的关键。 Period 是年、月、周、日、小时、分钟、秒和毫秒的数字。例如,一年半有两个部分,部分是 1,部分是 6。

您的输出跳过了部分和部分。

DateTime start = new DateTime ( 2017 , 1 , 29 , 0 , 0 , DateTimeZone.UTC );
DateTime stop = new DateTime ( 2018 , 1 , 28 , 0 , 0 , DateTimeZone.UTC );
Period p = new Period ( start , stop );
int[] differences = new int[ 7 ];
differences[ 0 ] = p.getYears ();
differences[ 1 ] = p.getMonths ();
differences[ 2 ] = p.getWeeks ();
differences[ 3 ] = p.getDays ();
differences[ 4 ] = p.getHours ();
differences[ 5 ] = p.getMinutes ();
differences[ 6 ] = p.getSeconds ();
System.out.println ( "differences: " + Arrays.toString ( differences ) );

运行时,我们看到十一个月零四个星期零两天。在 macOS El Capitan 上的 Java 8 Update 121 中运行 Joda-Time 2.8.2。

differences: [0, 11, 4, 2, 0, 0, 0]

您可能会想到调用 toStandardDays。但这样做会导致异常 (java.lang.UnsupportedOperationException) 说:“无法转换为天数,因为此期间包含月份且月份的长度各不相同”。

java.time

仅供引用:Joda-Time项目,现在在maintenance mode , 建议迁移到 java.time类。

在 java.time 中,未附加到时间线的时间跨度在 java.time.Period 中表示为年-月-日,在 中表示为小时-分钟-秒-纳秒java.time.Duration.

LocalDate类表示没有时间和时区的纯日期值。

java.time 类避开了构造函数,而是使用工厂方法。

LocalDate start = LocalDate.of ( 2017 , 1 , 29 );
LocalDate stop = LocalDate.of ( 2018 , 1 , 28 );
Period period = Period.between ( start , stop );
System.out.println ( "period.toString(): " + period );

toStringstandard ISO 8601 format for durations 中生成一段文本.我们在这里看到十一个月零三十天。显然 Joda-Time 和 java.time 计数不同。在这里我们看到了不同的结果。 Joda-Time 计算周,而 java.time 不计算。

period.toString(): P11M30D

关于android - JodaTime 期间返回意外结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41928454/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com