我有一系列包含开始日期和结束日期的范围。我想检查日期是否在该范围内。
用Date.before()和Date.after()似乎没有用。我真正需要的是像这样的伪代码:
boolean isWithinRange(Date testDate) {
return testDate >= startDate && testDate <= endDate;
}
不确定它是否相关,但我从数据库中提取的日期有时间戳。
发布于 2018-12-05 13:26:48
boolean isWithinRange(Date testDate) {
return !(testDate.before(startDate) || testDate.after(endDate));
}
我运行起来似乎还好。请注意,我这样写而不是
return testDate.after(startDate) && testDate.before(endDate);
因此即使testDate完全等于其中一个结束日期,它也会起作用。
发布于 2018-12-05 14:06:41
这是正确的方法。日历的工作方式相同。我能给你的最好的建议(根据你的例子)是这样的:
boolean isWithinRange(Date testDate) {
return testDate.getTime() >= startDate.getTime() &&
testDate.getTime() <= endDate.getTime();
}
Date.getTime()返回自格林威治标准时间1/1/1970 00:00:00以来的毫秒数,因为它很长,因此很容易比较。
https://stackoverflow.com/questions/-100001404
复制相似问题