Всё сильно зависит от цели, с которой мы эту разницу вычисляем. Но сразу в глаза бросается то, что 23 часа 59 минут такой метод переведет в 0 дней, что редко будет справедливым (хотя иногда так и должно быть).
Сам бы я написал такой говнокод:
public static int daysBetween(Date startDate, Date endDate)
{
int difInHours = (int) ((endDate.getTime() - startDate.getTime())/(1000*60*60));
int difInDays = (difInHours + 12) / 24;
}
Скорее тут проблема, что исходный код дает разницу в сутках, а надо узнать количество дней между двумя датами. Например между 0:10 1 января и 23:00 3 января вычислит как два дня, хотя на самом деле там только один день — 2 января. Т.е. раннюю дату надо привести к полночи текущего дня (минутой позже после 23:59), а позднюю — к 0:00. И после этого уже вычислить разницу.
Воу-воу! Как вы опрометчиво утверждаете «надо узнать количество дней между двумя датами». Тут даже условия нигде нет! Но с вашей формулировкой задачи ваши рассуждения справедливы, наверное.
ps: не хочу спорить, но напомню, что «Всё сильно зависит от цели, с которой мы эту разницу вычисляем.» и именно этого нам пока что никто не сказал.
На stackoverflow все советуют использовать чудо библиотеку Joda. С применением которой код выглядел бы так:
import java.util.Date;
import org.joda.time.DateTime;
import org.joda.time.Days;
public static int daysBetween(Date startDate, Date endDate)
{
return Days.daysBetween(new DateTime(startDate), new DateTime(endDate)).getDays();
}
Если использовать только стандартные классы, то можно и так, в таком случае будет хотя бы учитываться високосный год:
public static int daysBetween(Date startDate, Date endDate)
{
Calendar c1 = Calendar.getInstance();
c1.setTime(startDate);
Calendar c2 = Calendar.getInstance();
c2.setTime(endDate);
int daysBetween = 0;
while (c1.before(c2))
{
c1.add(Calendar.DAY_OF_MONTH,1);
daysBetween++;
}
return daysBetween;
}
Объясните, плиз, чем этот код плох.
Сам бы я написал такой говнокод:
ps: не хочу спорить, но напомню, что «Всё сильно зависит от цели, с которой мы эту разницу вычисляем.» и именно этого нам пока что никто не сказал.
Если использовать только стандартные классы, то можно и так, в таком случае будет хотя бы учитываться високосный год: