java 计算2个日期差的天数

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;


public class test16 {

 /**
  * @param args
  * @throws ParseException
  */
 public static void main(String[] args) throws ParseException {
  // TODO Auto-generated method stub
  SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  Date d1=sdf.parse("2012-09-08 10:10:10");
  Date d2=sdf.parse("2012-09-15 00:00:00");
  System.out.println(daysBetween(d1,d2));

  System.out.println(daysBetween("2012-09-08 10:10:10","2012-09-15 00:00:00"));
 }
 
 /**
     * 计算两个日期之间相差的天数
     * @param smdate 较小的时间
     * @param bdate  较大的时间
     * @return 相差天数
  * @throws ParseException
     */ 
    public static int daysBetween(Date smdate,Date bdate) throws ParseException 
    { 
     SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");
     smdate=sdf.parse(sdf.format(smdate));
     bdate=sdf.parse(sdf.format(bdate));
        Calendar cal = Calendar.getInstance(); 
        cal.setTime(smdate); 
        long time1 = cal.getTimeInMillis();              
        cal.setTime(bdate); 
        long time2 = cal.getTimeInMillis();      
        long between_days=(time2-time1)/(1000*3600*24);
         
       return Integer.parseInt(String.valueOf(between_days));        
    } 
   
/**
*字符串的日期格式的计算
*/
    public static int daysBetween(String smdate,String bdate) throws ParseException{
     SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");
        Calendar cal = Calendar.getInstance(); 
        cal.setTime(sdf.parse(smdate)); 
        long time1 = cal.getTimeInMillis();              
        cal.setTime(sdf.parse(bdate)); 
        long time2 = cal.getTimeInMillis();      
        long between_days=(time2-time1)/(1000*3600*24);
         
       return Integer.parseInt(String.valueOf(between_days));  
    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值