中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java如何實現日期處理工具類DateUtils

發布時間:2021-08-23 10:48:52 來源:億速云 閱讀:141 作者:小新 欄目:編程語言

小編給大家分享一下Java如何實現日期處理工具類DateUtils,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

具體內容如下

import java.sql.Timestamp; 
import java.text.ParseException; 
import java.text.SimpleDateFormat; 
import java.util.Calendar; 
import java.util.Date; 
 
/** 
 * <日期時間處理工具類> 
 */ 
public class DateUtils { 
  
 /** 
  * Date format pattern this is often used. 
  */ 
 public static final String PATTERN_YMD = "yyyy-MM-dd"; 
  
 /** 
  * Date format pattern this is often used. 
  */ 
 public static final String PATTERN_YMDHMS="yyyy-MM-dd HH:mm:ss"; 
  
 /** 
  * Formats the given date according to the YMD pattern. 
  * 
  * @param date The date to format. 
  * @return An YMD formatted date string. 
  * 
  * @see #PATTERN_YMD 
  */ 
 public static String formatDate(Date date) { 
  return formatDate(date, PATTERN_YMD); 
 } 
  
 /** 
  * Formats the given date according to the specified pattern. The pattern 
  * must conform to that used by the {@link SimpleDateFormat simple date 
  * format} class. 
  * 
  * @param date The date to format. 
  * @param pattern The pattern to use for formatting the date. 
  * @return A formatted date string. 
  * 
  * @throws IllegalArgumentException If the given date pattern is invalid. 
  * 
  * @see SimpleDateFormat 
  */ 
 public static String formatDate(Date date, String pattern) { 
  if (date == null) 
   throw new IllegalArgumentException("date is null"); 
  if (pattern == null) 
   throw new IllegalArgumentException("pattern is null"); 
   
  SimpleDateFormat formatter = new SimpleDateFormat(pattern); 
  return formatter.format(date); 
 } 
  
 /** 
  * Parses a date value. The format used for parsing the date value are retrieved from 
  * the default PATTERN_YMD. 
  * 
  * @param dateValue the date value to parse 
  * 
  * @return the parsed date 
  * 
  * @throws IllegalArgumentException If the given dateValue is invalid. 
  */ 
 public static Date parseDate(String dateValue) { 
  return parseDate(dateValue, null); 
 } 
  
 /** 
  * Parses the date value using the given date format. 
  * 
  * @param dateValue the date value to parse 
  * @param dateFormat the date format to use 
  * 
  * @return the parsed date. if parse is failed , return null 
  * 
  * @throws IllegalArgumentException If the given dateValue is invalid. 
  */ 
 public static Date parseDate(String dateValue, String dateFormat) { 
  if (dateValue == null) { 
   throw new IllegalArgumentException("dateValue is null"); 
  } 
  if (dateFormat == null) { 
   dateFormat = PATTERN_YMD; 
  } 
   
  SimpleDateFormat df = new SimpleDateFormat(dateFormat); 
  Date result = null; 
  try { 
   result = df.parse(dateValue); 
  } 
  catch (ParseException pe) { 
   pe.printStackTrace();// 日期型字符串格式錯誤 
  } 
  return result; 
 } 
  
 /** 
  * Adds a number of years to a date returning a new object. 
  * The original date object is unchanged. 
  * 
  * @param date the date, not null 
  * @param amount the amount to add, may be negative 
  * @return the new date object with the amount added 
  * @throws IllegalArgumentException if the date is null 
  */ 
 public static Date addYears(Date date, int amount) { 
  return add(date, Calendar.YEAR, amount); 
 } 
  
 /** 
  * Adds a number of years to a timestamp returning a new object. 
  * The original timestamp object is unchanged. 
  * 
  * @param timestamp the timestamp, not null 
  * @param amount the amount to add, may be negative 
  * @return the new timestamp object with the amount added 
  * @throws IllegalArgumentException if the timestamp is null 
  */ 
 public static Timestamp addYears(Timestamp timestamp, int amount) { 
  return add(timestamp, Calendar.YEAR, amount); 
 } 
  
 //----------------------------------------------------------------------- 
 /** 
  * Adds a number of months to a date returning a new object. 
  * The original date object is unchanged. 
  * 
  * @param date the date, not null 
  * @param amount the amount to add, may be negative 
  * @return the new date object with the amount added 
  * @throws IllegalArgumentException if the date is null 
  */ 
 public static Date addMonths(Date date, int amount) { 
  return add(date, Calendar.MONTH, amount); 
 } 
  
 /** 
  * Adds a number of months to a timestamp returning a new object. 
  * The original timestamp object is unchanged. 
  * 
  * @param timestamp the timestamp, not null 
  * @param amount the amount to add, may be negative 
  * @return the new timestamp object with the amount added 
  * @throws IllegalArgumentException if the timestamp is null 
  */ 
 public static Timestamp addMonths(Timestamp timestamp, int amount) { 
  return add(timestamp, Calendar.MONTH, amount); 
 } 
  
 //----------------------------------------------------------------------- 
 /** 
  * Adds a number of days to a date returning a new object. 
  * The original date object is unchanged. 
  * 
  * @param date the date, not null 
  * @param amount the amount to add, may be negative 
  * @return the new date object with the amount added 
  * @throws IllegalArgumentException if the date is null 
  */ 
 public static Date addDays(Date date, int amount) { 
  return add(date, Calendar.DATE, amount); 
 } 
  
 /** 
  * Adds a number of days to a timestamp returning a new object. 
  * The original timestamp object is unchanged. 
  * 
  * @param timestamp the timestamp, not null 
  * @param amount the amount to add, may be negative 
  * @return the new timestamp object with the amount added 
  * @throws IllegalArgumentException if the timestamp is null 
  */ 
 public static Timestamp addDays(Timestamp timestamp, int amount) { 
  return add(timestamp, Calendar.DATE, amount); 
 } 
  
 //----------------------------------------------------------------------- 
 /** 
  * Adds a number of minutes to a timestamp returning a new object. 
  * The original timestamp object is unchanged. 
  * 
  * @param timestamp the timestamp, not null 
  * @param amount the amount to add, may be negative 
  * @return the new timestamp object with the amount added 
  * @throws IllegalArgumentException if the timestamp is null 
  */ 
 public static Timestamp addMinutes(Timestamp timestamp, int amount) { 
  return add(timestamp, Calendar.MINUTE, amount); 
 } 
  
 /** 
  * Adds a number of days to current time returning a new object. 
  * 
  * @param amount the amount to add, may be negative 
  * @return the new timestamp object with the amount added 
  */ 
 public static Timestamp addDays(int amount) { 
  Calendar c = Calendar.getInstance(); 
  c.add(Calendar.DATE, amount); 
  return new Timestamp(c.getTimeInMillis()); 
 } 
  
 //----------------------------------------------------------------------- 
 /** 
  * Adds to a date returning a new object. 
  * The original date object is unchanged. 
  * 
  * @param date the date, not null 
  * @param calendarField the calendar field to add to 
  * @param amount the amount to add, may be negative 
  * @return the new date object with the amount added 
  * @throws IllegalArgumentException if the date is null 
  */ 
 private static Date add(Date date, int calendarField, int amount) { 
  if (date == null) { 
   throw new IllegalArgumentException("The date must not be null"); 
  } 
  Calendar c = Calendar.getInstance(); 
  c.setTime(date); 
  c.add(calendarField, amount); 
  return c.getTime(); 
 } 
  
 /** 
  * Adds to a timestamp returning a new object. 
  * The original timestamp object is unchanged. 
  * 
  * @param timestamp the timestamp, not null 
  * @param calendarField the calendar field to add to 
  * @param amount the amount to add, may be negative 
  * @return the new timestamp object with the amount added 
  * @throws IllegalArgumentException if the timestamp is null 
  */ 
 private static Timestamp add(Timestamp timestamp, int calendarField, int amount) { 
  if (timestamp == null) { 
   throw new IllegalArgumentException("The timestamp must not be null"); 
  } 
  Calendar c = Calendar.getInstance(); 
  c.setTime(timestamp); 
  c.add(calendarField, amount); 
  return new Timestamp(c.getTimeInMillis()); 
 } 
  
 /** 
  * <生成最小的當天日期值> 
  * @return 最小的當天日期值 
  */ 
 public static Timestamp now() { 
  Calendar c = Calendar.getInstance(); 
  c.set(Calendar.HOUR_OF_DAY, 0); 
  c.set(Calendar.MINUTE, 0); 
  c.set(Calendar.SECOND, 0); 
  c.set(Calendar.MILLISECOND, 0); 
  return new Timestamp(c.getTimeInMillis()); 
 } 
  
  
  
 /** This class should not be instantiated. */ 
 private DateUtils() { 
 } 
}

以上是“Java如何實現日期處理工具類DateUtils”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

松阳县| 晋江市| 红桥区| 皋兰县| 澄江县| 遂平县| 焦作市| 舒城县| 隆林| 增城市| 安阳县| 穆棱市| 宜宾市| 钟祥市| 拜城县| 禹城市| 通渭县| 麻阳| 巴林左旗| 唐山市| 钟祥市| 南部县| 定结县| 门源| 新干县| 聊城市| 五大连池市| 桂平市| 武胜县| 兰考县| 太和县| 抚顺县| 长子县| 中宁县| 新化县| 金湖县| 尚志市| 广州市| 莎车县| 淮滨县| 盐边县|