• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 1910
  • Last Modified:

How to calculate the number of days between two Dates?

I'm trying to write a function that will calculate the number of days that exist between two dates,  but have been unable to come up with an adequete solution thus far. In the reasearch that I've done, I've seen some methods convert the dates to milliseconds, subtract, then convert back. In others, they've incrimented a count variable, and simple added days to the earlier date until the two dates matched. Unfortunately, neither of these methods seems completely accurate under all conditions, nor do they seem as elegant as you'd hope them to be.

How have you done this calculation before? Is there a common library or standard function that's commonly used for this calculation?

Thanks in advance.
0
MehtaJasmin
Asked:
MehtaJasmin
  • 3
  • 2
  • 2
  • +1
1 Solution
 
CuteBugCommented:
0
 
objectsCommented:
the problem is more in the definition of what you mean by the number of days between two dates. Once that is defined then implementation is generally straight forward. Using a Calendar for the arithmetic is the standard way, and there are also libraries around.

So what is your definition of the number of days between 2 dates?

0
Never miss a deadline with monday.com

The revolutionary project management tool is here!   Plan visually with a single glance and make sure your projects get done.

 
MehtaJasminAuthor Commented:
My requirement is, if I pass dateA and dateB to the some java method /  API, it should return me how many days they are apart. It should consider if they in the same year/leap year etc. Basically I am coding for password expiry logic where I need to check that last time user has updated password, has it been 60 days yet. If current date is exceeding the 60 day period of validity then I need to prompt user to change the password.

I have dig in to java.util.Calendar API but could not find appropriate method. Also tried writing test program using DateUtils of commons package with getFragmentInDays() and iterator(java.util.Calendar focus,  int rangeStyle). But looks like I need to write quite a bit of math around iterator() to get the result out. So I was looking for any straight api / jar available for my need.

Hope this defines the question better.

Hope this clears the question.
0
 
objectsCommented:
Easiest way to do that is as well (or instead of) storing the last updated date, you store the expiry date. Then you just have to check if the current date is after the expiry date.
And if you don't store it you can just use the Calendar class to add the 60 day period to the last updated date and then compare with current date. Much simpler that calculating differences which is messy.

http://helpdesk.objects.com.au/java/how-do-i-add-a-specified-number-of-hours-to-a-java-date

(Use Calendar.DATE instead of Calendar.HOUR  to add days)
0
 
CEHJCommented:
For your two Date instances:
final int TIME_OUT_DURATION = 1000 * 60 * 60 * 24 * 60;
boolean needToChangePassword = (d1.getTime() - d2.getTime()) > TIME_OUT_DURATION;

Open in new window

0
 
MehtaJasminAuthor Commented:
Thanks! Actually had the same idea about the time you posted it. It's a much easier solution to our exact situation than attempting to calculate the time between two arbitrary dates. Thanks again!
0
 
objectsCommented:
thanks mate, let me know if you need any other help.

0

Featured Post

Upgrade your Question Security!

Your question, your audience. Choose who sees your identity—and your question—with question security.

  • 3
  • 2
  • 2
  • +1
Tackle projects and never again get stuck behind a technical roadblock.
Join Now