В 4-й строке кода (игнорировать пробелы и комментарии) и далее я вычисляю разницу в месяце между двумя датами. Это работает, но выглядит немного хакерским. Есть ли способ лучше?
int handleAllowance(LocalDate today) {
int allowance = membership.allowance();
if (allowance == 0) return 0;
// if update was last month (or earlier)
int months = today.monthOfYear().getMaximumValue() - today.monthOfYear().getMinimumValue(); // yeah, 12, but just to be 100% correct :-)
int curMonth = (today.getYear() * months) + today. getMonthOfYear();
int updMonth = (lastAllowanceUpdate.getYear() * months) + lastAllowanceUpdate.getMonthOfYear();
if (curMonth > updMonth) {
// ...and if today is on or past update day
int updateDay = Math.min(allowanceDay, today.dayOfMonth().getMaximumValue());
if (today.getDayOfMonth() >= updateDay) {
// number of months to give allowance (in the rare case this process fails to run for 2 months or more)
int allowanceMonths = curMonth - updMonth;
// give credits
final int totalAllowance = allowance * allowanceMonths;
giveCredits(totalAllowance);
// update day
lastAllowanceUpdate = lastAllowanceUpdate.plusMonths(allowanceMonths);
// return the allowance given
return totalAllowance;
}
}
return 0;
}
allowance
константа? В противном случаеfinal int totalAllowance = allowance * allowanceMonths;
может привести к другим результатам дляallowanceMonths > 1
по сравнению с запуском всей частиallowanceMonths
раз. - person Thomas   schedule 27.07.2011allowanceMonths
когда-либо действительно будет › 1 - person Bart van Heukelom   schedule 27.07.2011