欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java對日期Date類進(jìn)行加減運(yùn)算、年份加減月份加減、時(shí)間差等等

 更新時(shí)間:2017年01月01日 00:46:10   作者:Hi_YouXu  
這篇文章主要介紹了Java對日期Date類進(jìn)行加減運(yùn)算、年份加減月份加減、時(shí)間差等等,在網(wǎng)上查閱資料,加上自己總結(jié)的一些關(guān)于Date類的工具類

實(shí)現(xiàn)代碼一:

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

public class DateTestUtil { 
 public static void main(String[] args) throws Exception {  
  SimpleDateFormat sdf=new SimpleDateFormat("yyyyMMdd");
  String str="20110823";
  Date dt=sdf.parse(str);
  Calendar rightNow = Calendar.getInstance();
  rightNow.setTime(dt);
  rightNow.add(Calendar.YEAR,-1);//日期減1年
  rightNow.add(Calendar.MONTH,3);//日期加3個(gè)月
  rightNow.add(Calendar.DAY_OF_YEAR,10);//日期加10天
  Date dt1=rightNow.getTime();
  String reStr = sdf.format(dt1);
  System.out.println(reStr);
 }
}

注:在Calendar對象的add方法中,第二個(gè)參數(shù)為正數(shù)表示“加”,負(fù)數(shù)表示“減”。

代碼二: java date 日期加減天數(shù)

測試類代碼:

import java.text.SimpleDateFormat; 
import java.util.Date; 
 
public class DateTest { 
   
  public static void main(String[] arg){ 
    Date now = new Date();    
     
    addAndSubtractDaysByGetTime(now,-5); 
    addAndSubtractDaysByGetTime(now,5); 
    addAndSubtractDaysByCalendar(now,-5); 
    addAndSubtractDaysByCalendar(now,5); 
  } 
   
   public static Date addAndSubtractDaysByGetTime(Date dateTime/*待處理的日期*/,int n/*加減天數(shù)*/){ 
      
     //日期格式 
     SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd");  
     SimpleDateFormat dd=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");     
      
     System.out.println(df.format(new Date(dateTime.getTime() + n * 24 * 60 * 60 * 1000L))); 
     //System.out.println(dd.format(new Date(dateTime.getTime() + n * 24 * 60 * 60 * 1000L))); 
     //注意這里一定要轉(zhuǎn)換成Long類型,要不n超過25時(shí)會出現(xiàn)范圍溢出,從而得不到想要的日期值 
     return new Date(dateTime.getTime() + n * 24 * 60 * 60 * 1000L); 
   } 
    
   public static Date addAndSubtractDaysByCalendar(Date dateTime/*待處理的日期*/,int n/*加減天數(shù)*/){ 
      
     //日期格式 
     SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd");  
     SimpleDateFormat dd=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  
      
     java.util.Calendar calstart = java.util.Calendar.getInstance(); 
       calstart.setTime(dateTime); 
 
     calstart.add(java.util.Calendar.DAY_OF_WEEK, n);  
      
     System.out.println(df.format(calstart.getTime())); 
     //System.out.println(dd.format(calstart.getTime())); 
     return calstart.getTime(); 
   } 
 
}

運(yùn)行結(jié)果:
2014-10-06
2014-10-16
2014-10-06
2014-10-16

代碼三:

在網(wǎng)上查閱資料,加上自己總結(jié)的一些關(guān)于Date類的工具類。

package com.data.utils;

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

public class DateFormat {

 /**
  * 日期減幾年
  */
 public static String dateMinusYear(String str) throws Exception {

  SimpleDateFormat sdf = new SimpleDateFormat("yyyyMM");
  Date dt = sdf.parse(str);
  Calendar rightNow = Calendar.getInstance();
  rightNow.setTime(dt);
  rightNow.add(Calendar.YEAR, -1);// 日期減1年
  Date dt1 = rightNow.getTime();
  String reStr = sdf.format(dt1);
  return reStr;
 }

 /**
  * 日期加幾年
  */
 public static String dateAddYear(String str) throws Exception {

  SimpleDateFormat sdf = new SimpleDateFormat("yyyyMM");
  Date dt = sdf.parse(str);
  Calendar rightNow = Calendar.getInstance();
  rightNow.setTime(dt);
  rightNow.add(Calendar.YEAR, 1);// 日期加1年
  Date dt1 = rightNow.getTime();
  String reStr = sdf.format(dt1);
  return reStr;
 }

 /**
  * 日期減幾月
  */
 public static String dateMinusMonth(String str) throws Exception {

  SimpleDateFormat sdf = new SimpleDateFormat("yyyyMM");
  Date dt = sdf.parse(str);//將字符串生成Date
  Calendar rightNow = Calendar.getInstance();
  rightNow.setTime(dt);//使用給定的 Date 設(shè)置此 Calendar 的時(shí)間。 
  rightNow.add(Calendar.MONTH, -1);// 日期減1個(gè)月
  Date dt1 = rightNow.getTime();//返回一個(gè)表示此 Calendar 時(shí)間值的 Date 對象。
  String reStr = sdf.format(dt1);//將給定的 Date 格式化為日期/時(shí)間字符串,并將結(jié)果添加到給定的 StringBuffer。
  return reStr;
 }

 /**
  * 日期加幾月
  */
 public static String dateAddMonth(String str) throws Exception {

  SimpleDateFormat sdf = new SimpleDateFormat("yyyyMM");
  Date dt = sdf.parse(str);
  Calendar rightNow = Calendar.getInstance();
  rightNow.setTime(dt);
  rightNow.add(Calendar.MONTH, 1);// 日期加3個(gè)月
  // rightNow.add(Calendar.DAY_OF_YEAR,10);//日期加10天
  Date dt1 = rightNow.getTime();
  String reStr = sdf.format(dt1);
  return reStr;
 }

 /**
  * 獲取當(dāng)前年月的第一個(gè)月的str
  * @param str
  *   201505
  * @return 201501
  * @throws Exception
  */
 public static String dateOneMonth(String str) {

  str = str.substring(0, str.length() - 2);
  str = str + "01";
  return str;
 }

 /**
  * 算出所選月份距離一月份有幾個(gè)月。
  * @param str 201509
  * @return 9
  */
 public static int dateDistanceMonth(String str) {

  int i = Integer.parseInt(str);
  int j = Integer.parseInt(DateFormat.dateOneMonth(str));
  System.out.println(i - j);
  return i - j + 1;
 }

 /**
  * 獲取兩個(gè)時(shí)間的時(shí)間差,精確到毫秒
  * @param str
  * @return
  */
 public static String TimeDifference(long start, long end) {

  long between = end - start;
  long day = between / (24 * 60 * 60 * 1000);
  long hour = (between / (60 * 60 * 1000) - day * 24);
  long min = ((between / (60 * 1000)) - day * 24 * 60 - hour * 60);
  long s = (between / 1000 - day * 24 * 60 * 60 - hour * 60 * 60 - min * 60);
  long ms = (between - day * 24 * 60 * 60 * 1000 - hour * 60 * 60 * 1000
    - min * 60 * 1000 - s * 1000);
  String timeDifference = day + "天" + hour + "小時(shí)" + min + "分" + s + "秒" + ms
    + "毫秒";
  return timeDifference;
 }
}

 /**
  * 獲取24小時(shí)、一周、一個(gè)月的起始時(shí)間
  * 
  * @param timeInterval
  *   : DAY_TIME_INTERVAL WEEK_TIME_INTERVAL MONTH_TIME_INTERVAL
  * @return "yyyy-mm-dd hh:mm:ss"
  */
 public static String getStartTime(int timeInterval) {
  Calendar cal = Calendar.getInstance();
  SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  if (DAY_TIME_INTERVAL == timeInterval) {// 獲取24小時(shí)的起始時(shí)間
   cal.set(Calendar.HOUR_OF_DAY, 0);
   cal.set(Calendar.MINUTE, 0);
   cal.set(Calendar.SECOND, 0);
   String startTime = sdf.format(cal.getTime());
   return startTime;
  } else if (WEEK_TIME_INTERVAL == timeInterval) {
   int weekday = cal.get(Calendar.DAY_OF_WEEK) - 1;
   cal.add(Calendar.DATE, -weekday);
   cal.set(Calendar.HOUR_OF_DAY, 0);
   cal.set(Calendar.MINUTE, 0);
   cal.set(Calendar.SECOND, 0);
   String startTime = sdf.format(cal.getTime());
   return startTime;
  } else if (MONTH_TIME_INTERVAL == timeInterval) {
   int dayofmonthMin = cal.getActualMinimum(Calendar.DAY_OF_MONTH);
   // c.add(Calendar.DATE, -dayofmonth);
   cal.set(Calendar.DATE, dayofmonthMin);
   cal.set(Calendar.HOUR_OF_DAY, 0);
   cal.set(Calendar.MINUTE, 0);
   cal.set(Calendar.SECOND, 0);
   String startTime = sdf.format(cal.getTime());
   return startTime;
  }
  return null;
 }

 /**
  * 獲取24小時(shí)、一周、一個(gè)月的結(jié)束時(shí)間
  * 
  * @param timeInterval
  *   : DAY_TIME_INTERVAL WEEK_TIME_INTERVAL MONTH_TIME_INTERVAL
  * @return "yyyy-mm-dd hh:mm:ss"
  */
 public static String getEndTime(int timeInterval) {
  Calendar cal = Calendar.getInstance();
  cal.setTimeZone(TimeZone.getTimeZone("GMT+8"));
  SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  if (DAY_TIME_INTERVAL == timeInterval) {
   cal.set(Calendar.HOUR_OF_DAY, 23);
   cal.set(12, 59);
   cal.set(13, 59);
   long date = cal.getTimeInMillis();
   String endTime = sdf.format(new Date(date));
   return endTime;
  } else if (WEEK_TIME_INTERVAL == timeInterval) {
   int weekday = cal.get(Calendar.DAY_OF_WEEK) - 1;
   cal.add(Calendar.DATE, -weekday);
   cal.add(Calendar.DATE, 6);
   cal.set(Calendar.HOUR_OF_DAY, 23);
   cal.set(12, 59);
   cal.set(13, 59);
   long date = cal.getTimeInMillis();
   String endTime = sdf.format(new Date(date));
   return endTime;
  } else if (MONTH_TIME_INTERVAL == timeInterval) {
   int dayOfMonthMax = cal.getActualMaximum(Calendar.DAY_OF_MONTH);
   cal.set(Calendar.DATE, dayOfMonthMax);
   cal.set(Calendar.HOUR_OF_DAY, 23);
   cal.set(Calendar.MINUTE, 59);
   cal.set(Calendar.SECOND, 59);
   String endTime = sdf.format(cal.getTime());
   return endTime;
  }
  return null;
 }
 /**
  * 判斷dateStr是否在start和end中間,start和end都可以為null yyyyMMddHHmmss或者yyyyMMdd格式
  * 
  * @author you.xu
  * @date 2015年8月19日下午3:11:46
  * @param dateStr
  * @param start
  * @param end
  * @return
  */
 public static boolean checkDateVal(String dateStr, String start, String end) {
  boolean isDateRight = false;
  Date date = null;
  Date startDate = null;
  Date endDate = null;
  SimpleDateFormat sdf = null;
  // 判斷日期格式
  if (14 == dateStr.length()) {
   sdf = new SimpleDateFormat("yyyyMMddHHmmss");
  } else if (8 == dateStr.length()) {
   sdf = new SimpleDateFormat("yyyyMMdd");
  } else
   return false;

  try {
   // 更改判斷日期格式
   date = sdf.parse(dateStr);
  } catch (ParseException e) {
   log.error(e, e);
  }

  if ((start == null) && (end != null)) {
   try {
    endDate = sdf.parse(end);
   } catch (ParseException ex1) {
    log.error(ex1, ex1);
   }
   if ((date != null) && (endDate != null))// Check parameters for
   {
    if (date.compareTo(endDate) <= 0)
     isDateRight = true;
   }
  } else if ((start != null) && (end == null)) {
   try {
    startDate = sdf.parse(start);
   } catch (ParseException ex1) {
    log.error(ex1, ex1);
   }
   if ((date != null) && (startDate != null)) {
    if (date.compareTo(startDate) >= 0)
     isDateRight = true;
   }
  } else if ((start != null) && (end != null)) {
   try {
    startDate = sdf.parse(start);
    endDate = sdf.parse(end);
   } catch (ParseException ex2) {
    System.out.println(ex2.toString());
   }
   if ((startDate != null) && (date != null) && (endDate != null)) {
    if ((date.compareTo(startDate) >= 0)
      && (date.compareTo(endDate) <= 0))
     isDateRight = true;
   }
  }
  return isDateRight;
 }

 /**
  * 判斷dateStr是否在start和end中間,start和end都可以為null long形格式
  * 
  * @author you.xu
  * @date 2015年8月19日下午3:12:35
  * @param dateStr
  * @param start
  * @param end
  * @return
  */
 public static boolean checkDateV(String dateStr, String start, String end) {
  boolean isDateRight = false;
  long date = -1;
  long fromDate = -1;
  long toDate = -1;

  date = java.lang.Long.parseLong(dateStr);

  if ((start == null) && (end == null)) {
   isDateRight = true;
  } else if ((start == null) && (end != null)) {
   try {
    toDate = java.lang.Long.parseLong(end);
   } catch (NumberFormatException nfe) {
    log.error(nfe, nfe);
   }
   if (date <= toDate) {
    isDateRight = true;
   }
  } else if ((start != null) && (end == null)) {
   try {
    fromDate = java.lang.Long.parseLong(start);
   } catch (NumberFormatException nfe) {
    log.error(nfe, nfe);
   }

   if (date >= fromDate) {
    isDateRight = true;
   }
  } else if ((start != null) && (end != null)) {
   try {
    toDate = java.lang.Long.parseLong(end);
    fromDate = java.lang.Long.parseLong(start);
   } catch (NumberFormatException nfe) {
    log.error(nfe, nfe);
   }

   if ((date <= toDate) && (date >= fromDate)) {
    isDateRight = true;
   }
  }
  return isDateRight;
 }

目前就用到了這些,隨時(shí)添加,有簡單方便的時(shí)間工具類,希望和大家一起學(xué)習(xí),在評論中指出。thanks?。?!

相關(guān)文章

  • SpringBoot整合mybatis-plus實(shí)現(xiàn)分頁查詢功能

    SpringBoot整合mybatis-plus實(shí)現(xiàn)分頁查詢功能

    這篇文章主要介紹了SpringBoot整合mybatis-plus實(shí)現(xiàn)分頁查詢功能,pringBoot分頁查詢的兩種寫法,一種是手動實(shí)現(xiàn),另一種是使用框架實(shí)現(xiàn),現(xiàn)在我將具體的實(shí)現(xiàn)流程分享一下,需要的朋友可以參考下
    2023-11-11
  • SpringBoot整合JPA框架實(shí)現(xiàn)過程講解

    SpringBoot整合JPA框架實(shí)現(xiàn)過程講解

    在開發(fā)中,我們通常會對數(shù)據(jù)庫的數(shù)據(jù)進(jìn)行操作,Sprirng?Boot對關(guān)系型數(shù)據(jù)庫和非關(guān)系型數(shù)據(jù)庫的訪問操作都提供了非常好的整合支持
    2022-12-12
  • Springboot詳解整合SpringSecurity實(shí)現(xiàn)全過程

    Springboot詳解整合SpringSecurity實(shí)現(xiàn)全過程

    Spring Security基于Spring開發(fā),項(xiàng)目中如果使用Springboot作為基礎(chǔ),配合Spring Security做權(quán)限更加方便,而Shiro需要和Spring進(jìn)行整合開發(fā)。因此作為spring全家桶中的Spring Security在java領(lǐng)域很常用
    2022-07-07
  • springboot cloud使用eureka整合分布式事務(wù)組件Seata 的方法

    springboot cloud使用eureka整合分布式事務(wù)組件Seata 的方法

    這篇文章主要介紹了springboot cloud使用eureka整合分布式事務(wù)組件Seata 的方法 ,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-05-05
  • 詳解java8中的Stream數(shù)據(jù)流

    詳解java8中的Stream數(shù)據(jù)流

    Stream使用一種類似用SQL語句從數(shù)據(jù)庫查詢數(shù)據(jù)的直觀方式來提供一種對Java集合運(yùn)算和表達(dá)的高階抽象。接下來通過本文給大家分享java8中的Stream數(shù)據(jù)流知識,感興趣的朋友一起看看吧
    2017-10-10
  • Java聊天室之使用Socket實(shí)現(xiàn)傳遞圖片

    Java聊天室之使用Socket實(shí)現(xiàn)傳遞圖片

    這篇文章主要為大家詳細(xì)介紹了Java簡易聊天室之使用Socket實(shí)現(xiàn)傳遞圖片功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以了解一下
    2022-10-10
  • Java中對象的序列化詳解及實(shí)例

    Java中對象的序列化詳解及實(shí)例

    這篇文章主要介紹了 Java中對象的序列化詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • 最新評論