今天在写一个流量控制的模块,要做一个根据输入的时间,获得下一天0点0分0秒的时间戳。
程序非常简单,习惯性地做了个单元测试。尽然没有通过
这怎么可能!!明明应该是对的啊。后来打出时间来,看了下。输出的结果是
2010-01-13 12:00:00.000
是小时域有问题。仔细阅读了JavaDoc后发现,不能使用clear(Calendar.HOUR_OF_DAY)来清除小时域;clear(Calendar.HOUR)也不行。
还是老老实实用set(Calendar.HOUR_OF_DAY,0)来清除小时域。最后干脆全部用set方法了。
正确的版本是这样的:
public long caculateResetTimestamp(long currentTimestamp) {
Calendar cal = Calendar.getInstance();
cal.setTimeInMillis(currentTimestamp);
cal.clear(Calendar.MILLISECOND);
cal.clear(Calendar.SECOND);
cal.clear(Calendar.MINUTE);
cal.clear(Calendar.HOUR);
cal.clear(Calendar.HOUR_OF_DAY);
cal.roll(Calendar.DATE, true);
return cal.getTimeInMillis();
}
程序非常简单,习惯性地做了个单元测试。尽然没有通过
DateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
DailyResetPolicy resetPolicy = new DailyResetPolicy();
@Test
public void testCaculateResetTimestamp() throws ParseException {
long input = toMillis("2010-01-12 12:12:23.234");
long expected = toMillis("2010-01-13 00:00:00.000");
long result = resetPolicy.caculateResetTimestamp(input);
assertEquals(expected, result);
}
long toMillis(String source) throws ParseException {
return format.parse(source).getTime();
}
这怎么可能!!明明应该是对的啊。后来打出时间来,看了下。输出的结果是
2010-01-13 12:00:00.000
是小时域有问题。仔细阅读了JavaDoc后发现,不能使用clear(Calendar.HOUR_OF_DAY)来清除小时域;clear(Calendar.HOUR)也不行。
还是老老实实用set(Calendar.HOUR_OF_DAY,0)来清除小时域。最后干脆全部用set方法了。
正确的版本是这样的:
public long caculateResetTimestamp(long currentTimestamp) {
Calendar cal = Calendar.getInstance();
cal.setTimeInMillis(currentTimestamp);
cal.set(Calendar.MILLISECOND, 0);
cal.set(Calendar.SECOND, 0);
cal.set(Calendar.MINUTE, 0);
cal.set(Calendar.HOUR_OF_DAY, 0);
cal.roll(Calendar.DATE, true);
return cal.getTimeInMillis();
}
Java时间戳计算修正
991

被折叠的 条评论
为什么被折叠?



