时间不在于你拥有多少,而在于你怎样使用。

本文介绍Java中日期时间的转换、比较及加减操作方法,包括Date、Timestamp与String之间的转换,时间戳的获取,时间差的计算,以及利用Calendar进行时间加减。

①时间类型的相互转换

(1) Date ->Timestamp

父类不能直接向子类转化,可借助中间的String~~~~

(2) Timestamp -> Date

  Timestamp ts = new Timestamp(System.currentTimeMillis());
  Date date = new Date();
    try {
        date = ts;
        System.out.println(date);
          } catch (Exception e) {
            e.printStackTrace();
        }

 

(3)Date -> String

        String dateStr = "";
        Date date = new Date();
        //format的格式可以任意
        DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
        DateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH/mm/ss");
        try {
            dateStr = sdf.format(date);
            System.out.println(dateStr);
            dateStr = sdf2.format(date);
            System.out.println(dateStr);
        } catch (Exception e) {
            e.printStackTrace();
        }

(4) Timestamp -> String

                Timestamp ts = new Timestamp(System.currentTimeMillis());
        String tsStr = "";
        DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
        try {
            //方法一
            tsStr = sdf.format(ts);
            System.out.println(tsStr);
            //方法二
            tsStr = ts.toString();
            System.out.println(tsStr);
        } catch (Exception e) {
            e.printStackTrace();
        }

很容易能够看出来,方法一的优势在于可以灵活的设置字符串的形式。

(5) String -> Date

                String dateStr = "2010/05/04 12:34:23";
        Date date = new Date();
        //注意format的格式要与日期String的格式相匹配
        DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
        try {
            date = sdf.parse(dateStr);
            System.out.println(date.toString());
        } catch (Exception e) {
            e.printStackTrace();
        }

(6) String -> Timestamp

                Timestamp ts = new Timestamp(System.currentTimeMillis());
        String tsStr = "2011-05-09 11:49:45";
        try {
            ts = Timestamp.valueOf(tsStr);
            System.out.println(ts);
        } catch (Exception e) {
            e.printStackTrace();
        }

注:String的类型必须形如: yyyy-mm-dd hh:mm:ss[.f...] 这样的格式,中括号表示可选,否则报错!!!

    如果String为其他格式,可考虑重新解析下字符串,再重组~~

 ②时间比较

(1)时间比较

String s1="2008-01-25 09:12:09";

String s2="2008-01-29 09:12:11";

java.text.DateFormat df=new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

java.util.Calendar c1=java.util.Calendar.getInstance();

java.util.Calendar c2=java.util.Calendar.getInstance();

try{

  c1.setTime(df.parse(s1));

  c2.setTime(df.parse(s2));

}catch(java.text.ParseException e){

  System.err.println("格式不正确");

}

int result=c1.compareTo(c2);

if(result==0)

  System.out.println("c1相等c2");

else if(result<0)

  System.out.println("c1小于c2");

else

  System.out.println("c1大于c2");

(2) 时间差
前提:两个String类型的时间点 String date1 = 2004-03-26 13:31:40 ;String date1 = 2004-01-02 11:30:24

1、方法一

DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

try

{

    Date d1 = df.parse("date1");

    Date d2 = df.parse("date2");

    long diff = d1.getTime() - d2.getTime();

    long days = diff / (1000 * 60 * 60 * 24);

}

catch (Exception e)

{

}

2、方法二

SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

   java.util.Date now = df.parse("2004-03-26 13:31:40");

   java.util.Date date=df.parse("2004-01-02 11:30:24");

   long l=now.getTime()-date.getTime();

   long day=l/(24*60*60*1000);

   long hour=(l/(60*60*1000)-day*24);

   long min=((l/(60*1000))-day*24*60-hour*60);

   long s=(l/1000-day*24*60*60-hour*60*60-min*60);

   System.out.println(""+day+"天"+hour+"小时"+min+"分"+s+"秒");

3、方法三

SimpleDateFormat dfs = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

   java.util.Date begin=dfs.parse("2004-01-02 11:30:24");

   java.util.Date end = dfs.parse("2004-03-26 13:31:40");

   long between=(end.getTime()-begin.getTime())/1000;//除以1000是为了转换成秒

   long day1=between/(24*3600);

   long hour1=between%(24*3600)/3600;

   long minute1=between600/60;

   long second1=between`/60;

   System.out.println(""+day1+"天"+hour1+"小时"+minute1+"分"+second1+"秒");

 

 ③时间加减

(1) 已当前时间为准

         SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
         java.util.Calendar cal=java.util.Calendar.getInstance();
         cal.setTime(new Date());
         System.out.println(dateFormat.format(new Date())); 
         cal.add(Calendar.MINUTE, -1);
         System.out.println("当前时间的前一分钟***"+dateFormat.format(cal.getTime())); 
         cal.add(Calendar.HOUR, -1);
         System.out.println("当前时间的前一小时***"+dateFormat.format(cal.getTime()));
         cal.add(Calendar.SECOND, -1);
         System.out.println("当前时间的前一秒***"+dateFormat.format(cal.getTime()));
         cal.add(Calendar.YEAR, -1);
         System.out.println("当前时间的前一年***"+dateFormat.format(cal.getTime()));
         cal.add(Calendar.MONTH, -1);
         System.out.println("当前时间的前一月***"+dateFormat.format(cal.getTime()));
         cal.add(Calendar.DAY_OF_YEAR, -1);
         System.out.println("当前时间的前一天***"+dateFormat.format(cal.getTime()));
         cal.add(Calendar.DAY_OF_MONTH, -1);
         System.out.println("当前时间的前一天***"+dateFormat.format(cal.getTime()));
         cal.add(Calendar.DAY_OF_WEEK, -1);
         System.out.println("当前时间的前一天***"+dateFormat.format(cal.getTime()));
         cal.add(Calendar.MAY, -1);
         System.out.println("当前时间的前一周***"+dateFormat.format(cal.getTime()));
         //输出结果
         当前时间*****2015-11-27 09:38:27
         当前时间的前一分钟**2015-11-27 09:37:27
         当前时间的前一小时**2015-11-27 08:37:27
         当前时间的前一秒***2015-11-27 08:37:26
         当前时间的前一年***2014-11-27 08:37:26
         当前时间的前一月***2014-10-27 08:37:26
         当前时间的前一天***2014-10-26 08:37:26
         当前时间的前一天***2014-10-25 08:37:26
         当前时间的前一天***2014-10-24 08:37:26
         当前时间的前一周***2014-10-17 08:37:26

 


 

 

转载于:https://www.cnblogs.com/Crysta1/p/4962261.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值