Java 如何使用Joda Time检查DateTime是否发生重复事件?
我有一个Java 如何使用Joda Time检查DateTime是否发生重复事件?,java,performance,time,jodatime,Java,Performance,Time,Jodatime,我有一个DateTime,它表示一个重复事件的开始。A天(日周期)将表示重复周期。我认为这一反复发生的事件永远不会停止 from = "2013-06-27" period = 3 days nextOccurence will be "2013-06-30", "2013-07-03", "2013-07-06", and so on. "2013-07-03" is an occurence but "2013-07-04" isn't an occurence. 我想知道就性能而言,
DateTime
,它表示一个重复事件的开始。A天
(日周期)将表示重复周期。我认为这一反复发生的事件永远不会停止
from = "2013-06-27"
period = 3 days
nextOccurence will be "2013-06-30", "2013-07-03", "2013-07-06", and so on.
"2013-07-03" is an occurence but "2013-07-04" isn't an occurence.
我想知道就性能而言,什么是确定
DateTime
是否是重复事件发生的最佳方法?从长远来看,程序将需要检查“2014-07-03”或“2015-07-03”是否发生。您始终可以在日历
类中使用添加
方法
你可以做以下事情-
Date date = "2013-06-27" ;
Calendar cal = Calendar.getInstance();
cal.setTime(date);
cal.add(Calendar.DATE, 3); // add 3 days
date = cal.getTime();
等等…您可以在
日历
类中始终使用添加
方法
你可以做以下事情-
Date date = "2013-06-27" ;
Calendar cal = Calendar.getInstance();
cal.setTime(date);
cal.add(Calendar.DATE, 3); // add 3 days
date = cal.getTime();
以此类推……这在我的机器上以180毫秒的速度运行所有五次检查。或者大约每秒27次检查,在这里你检查的是300年后的某个日期
@Test
public void isOccurrence() {
long startTime = System.currentTimeMillis();
assertTrue(isOccurrence(new DateMidnight(2010, 1, 10), 3, new DateTime(2010, 1, 19, 0, 0)));
assertFalse(isOccurrence(new DateMidnight(2010, 1, 10), 3, new DateTime(2010, 1, 18, 0, 0)));
assertTrue(isOccurrence(new DateMidnight(2010, 1, 10), 3, new DateTime(2310, 1, 19, 0, 0)));
assertFalse(isOccurrence(new DateMidnight(2010, 1, 10), 3, new DateTime(2310, 1, 20, 0, 0)));
assertTrue(isOccurrence(new DateMidnight(2010, 1, 10), 3, new DateTime(2010, 1, 10, 0, 0)));
System.out.println("elapsed=" + (System.currentTimeMillis() - startTime));
}
public boolean isOccurrence(DateMidnight startDate, int dayIncrement, DateTime testTime) {
DateMidnight testDateMidnight = testTime.toDateMidnight();
while (startDate.isBefore(testDateMidnight)) {
startDate = startDate.plusDays(dayIncrement);
}
return startDate.equals(testDateMidnight);
}
这在我的机器上以180毫秒的时间运行所有五次检查。或者大约每秒27次检查,在这里你检查的是300年后的某个日期
@Test
public void isOccurrence() {
long startTime = System.currentTimeMillis();
assertTrue(isOccurrence(new DateMidnight(2010, 1, 10), 3, new DateTime(2010, 1, 19, 0, 0)));
assertFalse(isOccurrence(new DateMidnight(2010, 1, 10), 3, new DateTime(2010, 1, 18, 0, 0)));
assertTrue(isOccurrence(new DateMidnight(2010, 1, 10), 3, new DateTime(2310, 1, 19, 0, 0)));
assertFalse(isOccurrence(new DateMidnight(2010, 1, 10), 3, new DateTime(2310, 1, 20, 0, 0)));
assertTrue(isOccurrence(new DateMidnight(2010, 1, 10), 3, new DateTime(2010, 1, 10, 0, 0)));
System.out.println("elapsed=" + (System.currentTimeMillis() - startTime));
}
public boolean isOccurrence(DateMidnight startDate, int dayIncrement, DateTime testTime) {
DateMidnight testDateMidnight = testTime.toDateMidnight();
while (startDate.isBefore(testDateMidnight)) {
startDate = startDate.plusDays(dayIncrement);
}
return startDate.equals(testDateMidnight);
}
如果我在检查2015年或2017年的日期,这将是一个很大的循环。这会造成性能问题还是可以忽略不计?您不能做更多的事情。有
DateUtils
,但它不允许您定义3天,而允许您定义一个迭代器的周或月。我认为这是唯一可能的解决方案。在接受你的回答之前,我会等待更多的反馈。谢谢。如果我在检查2015年或2017年的日期,这将是一个很大的循环。这会造成性能问题还是可以忽略不计?您不能做更多的事情。有DateUtils
,但它不允许您定义3天,而允许您定义一个迭代器的周或月。我认为这是唯一可能的解决方案。在接受你的回答之前,我会等待更多的反馈。谢谢。你帮我避免了过早的优化!我一直在考虑重新设计我的课程,但现在我知道这是不值得的。谢谢你@Keith顺便说一句,Joda Time中所有与“午夜”相关的类和方法都已被弃用。改用较新的方法。但这个问题并不影响这个答案的逻辑。或者LocalDate
在这里合适吗?你让我免于过早的优化!我一直在考虑重新设计我的课程,但现在我知道这是不值得的。谢谢你@Keith顺便说一句,Joda Time中所有与“午夜”相关的类和方法都已被弃用。改用较新的方法。但这个问题并不影响这个答案的逻辑。或者LocalDate
在这里合适吗?