Java中怎么利用Calendar計(jì)算時(shí)間,相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。
10年積累的成都做網(wǎng)站、成都網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有奎屯免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
Java實(shí)例大全
@Test public void test4(){ SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); /* * 獲取15天后是多少號(hào)? * * add(int field,int n) * 為當(dāng)前calendar指定時(shí)間分量上累加給定值 * 若傳入的是負(fù)數(shù),則是累減 */ Calendar calendar = Calendar.getInstance(); calendar.add(Calendar.DAY_OF_YEAR, 15); //給當(dāng)前時(shí)間加15天 //System.out.println(calendar.getTime()); System.out.println(sdf.format(calendar.getTime())); /* * 三個(gè)月零十天后的那周的星期三是幾號(hào)? */ Calendar cal = Calendar.getInstance(); cal.add(Calendar.MONTH, 3); //給當(dāng)前時(shí)間加3個(gè)月 cal.add(Calendar.DAY_OF_YEAR, 10); //給當(dāng)前時(shí)間加10天 //得出三個(gè)月十天后的日期,然后將日期設(shè)為當(dāng)周星期三 cal.set(Calendar.DAY_OF_WEEK, 4); //1是周天,所以4是周三 //System.out.println(cal.getTime()); System.out.println(sdf.format(cal.getTime())); /* * 獲取某個(gè)時(shí)間分量所允許的最大值 * 獲取今年最大天數(shù) */ Calendar cal1 = Calendar.getInstance(); int days = cal1.getActualMaximum(Calendar.DAY_OF_YEAR); System.out.println("今年最大天數(shù)為:"+days+"天"); /* * 一周的第一天是星期日 * 獲取當(dāng)前是星期幾 */ Calendar cal2 = Calendar.getInstance(); int w = cal2.get(Calendar.DAY_OF_WEEK); System.out.println("今天是星期:"+(w==1?7:w-1)); }
結(jié)果:
/** 獲取15天后是多少號(hào)?*/2019-10-29 14:25:59/** 三個(gè)月零十天后的那周的星期三是幾號(hào)?*/2020-01-22 14:25:59/** 獲取今年最大天數(shù)*/今年最大天數(shù)為:365天/** 獲取當(dāng)前是星期幾*/今天是星期:1
例子:
/**** * 傳入具體日期 ,返回具體日期增加一個(gè)月。 * @param date 日期(2017-04-13) * @return 2017-05-13* @throws ParseException */ private String subMonth(String date) throws ParseException { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Date dt = sdf.parse(date); Calendar rightNow = Calendar.getInstance(); rightNow.setTime(dt); rightNow.add(Calendar.MONTH, 1); Date dt1 = rightNow.getTime(); String reStr = sdf.format(dt1); return reStr;
獲取時(shí)間
// 使用默認(rèn)時(shí)區(qū)和語言環(huán)境獲得一個(gè)日歷Calendar cal = Calendar.getInstance();// 賦值時(shí)年月日時(shí)分秒常用的6個(gè)值,注意月份下標(biāo)從0開始,所以取月份要+1System.out.println("年:" + cal.get(Calendar.YEAR));System.out.println("月:" + (cal.get(Calendar.MONTH) + 1)); System.out.println("日:" + cal.get(Calendar.DAY_OF_MONTH));System.out.println("時(shí):" + cal.get(Calendar.HOUR_OF_DAY));System.out.println("分:" + cal.get(Calendar.MINUTE));System.out.println("秒:" + cal.get(Calendar.SECOND));
今天是 2018 年 2 月 12 日,運(yùn)行結(jié)果:
年:2018月:2日:12時(shí):15分:57秒:39
設(shè)置時(shí)間
月份的下標(biāo)從 0 開始,設(shè)置時(shí)同樣需要注意,比如我們?cè)O(shè)置為 2 月 15 日除夕當(dāng)晚的倒計(jì)時(shí)的最后一秒: 2018-02-15 23:59:59 可以這樣:
Calendar cal = Calendar.getInstance();// 如果想設(shè)置為某個(gè)日期,可以一次設(shè)置年月日時(shí)分秒,由于月份下標(biāo)從0開始賦值月份要-1// cal.set(year, month, date, hourOfDay, minute, second);cal.set(2018, 1, 15, 23, 59, 59);
或者也可以單個(gè)字段一一設(shè)置:
// 或者6個(gè)字段分別進(jìn)行設(shè)置,由于月份下標(biāo)從0開始賦值月份要-1cal.set(Calendar.YEAR, 2018);cal.set(Calendar.MONTH, Calendar.FEBRUARY);cal.set(Calendar.DAY_OF_MONTH, 15);cal.set(Calendar.HOUR_OF_DAY, 23);cal.set(Calendar.MINUTE, 59);cal.set(Calendar.SECOND, 59);System.out.println(cal.getTime());
打印的時(shí)間結(jié)果為:
Thu Feb 15 23:59:59 CST 2018
時(shí)間計(jì)算
add方法:
比如在除夕當(dāng)晚最后一秒,add 一秒:
Calendar cal = Calendar.getInstance();System.out.println(cal.getTime());cal.set(2018, 1, 15, 23, 59, 59);cal.add(Calendar.SECOND, 1);System.out.println(cal.getTime());
打印時(shí)間結(jié)果如下,日期會(huì)自動(dòng)進(jìn)入下一天:
Thu Feb 15 23:59:59 CST 2018Fri Feb 16 00:00:00 CST 2018
再比如 1 月 31 號(hào)的時(shí)候,月份加一,會(huì)出現(xiàn)怎樣結(jié)果:
Calendar cal = Calendar.getInstance();cal.set(2018, 1, 31, 8, 0, 0);System.out.println(cal.getTime());cal.add(Calendar.MONTH, 1);System.out.println(cal.getTime());
運(yùn)行結(jié)果:
Wed Jan 31 08:00:00 CST 2018Wed Feb 28 08:00:00 CST 2018
看完上述內(nèi)容,你們掌握J(rèn)ava中怎么利用Calendar計(jì)算時(shí)間的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!