一篇文章弄懂Java8中的時(shí)間處理
前言
java8借鑒了第三方日期庫joda很多的優(yōu)點(diǎn)
java.time包
類名 | 描述 |
---|---|
Instant | 時(shí)間戳 |
Duration | 持續(xù)時(shí)間,時(shí)間差 |
LocalDate | 只包含日期,比如:2020-05-20 |
LocalTime | 只包含時(shí)間,比如:13:14:00 |
LocalDateTime | 包含日期和時(shí)間,比如:2020-05-20 13:14:00 |
Period | 時(shí)間段 |
ZoneOffset | 時(shí)區(qū)偏移量,比如:+8:00 |
ZonedDateTime | 帶時(shí)區(qū)的時(shí)間 |
Clock | 時(shí)鐘,比如獲取目前美國紐約的時(shí)間 |
java.time.format包
類名 | 描述 |
---|---|
DateTimeFormatter | 時(shí)間格式化 |
Java8提供了全新的時(shí)間處理框架,這里就可以完全丟棄之前的Date、Calendar了。
具體的API的使用都是比較簡(jiǎn)單的。這里就不展開介紹了。
這里主要介紹下一些主要的類
LocalDateTime
我們一般常用的就是這個(gè)了,用這個(gè)來表示日期時(shí)間。如LocalDateTime.now()
就可以基于當(dāng)前默認(rèn)時(shí)區(qū)得到當(dāng)前的日期時(shí)間。
由于全球有好多時(shí)區(qū),同一個(gè)日期時(shí)間,在不同的時(shí)區(qū),反映到時(shí)間軸上是不同的。
LocalDateTime類型的日期時(shí)間是沒包含時(shí)區(qū),所以它不能對(duì)應(yīng)到時(shí)間軸上。說的直白點(diǎn)就是LocalDateTime不能轉(zhuǎn)換成自 1970-01-01T00:00:00Z 紀(jì)元以來的毫秒數(shù)。
ZonedDateTime
ZonedDateTime可以理解就是在LocalDateTime的基礎(chǔ)上添加上時(shí)區(qū),所以它是可以反映到時(shí)間軸上的。
下面用夏令時(shí)舉個(gè)例子來看看LocalDateTime和LocalDateTime的區(qū)別。
夏令時(shí)是什么這里就不展開了,具體可以網(wǎng)上查下??纯次覈?986開始的夏令時(shí)。
簡(jiǎn)單來說就是在夏令時(shí)開始的時(shí)候,將時(shí)鐘向后撥1個(gè)小時(shí)。對(duì)應(yīng)我國1986年開始的夏令時(shí)的做法,就是在每年四月中旬的第一個(gè)星期日當(dāng)時(shí)鐘到達(dá)凌晨2點(diǎn)時(shí),直接將時(shí)鐘撥到凌晨3點(diǎn)。也就是凌晨1點(diǎn)和凌晨3點(diǎn)之間之差1個(gè)小時(shí)。
由于1986年是開始實(shí)施的,所以1986年的夏令時(shí)是1986年5月4日開始的。
我們看看1987年的夏令時(shí)開始
根據(jù)我國當(dāng)時(shí)的夏令時(shí)政策,1987年應(yīng)該是1987年4月12日開始的。具體來說就是在1987-04-12 01:00:00 過一個(gè)小時(shí)后,時(shí)間應(yīng)該是1987-04-12 03:00:00
LocalDateTime localDateTime = LocalDateTime.of(1987, 4, 12, 1, 0, 0, 0); System.out.println(localDateTime); System.out.println(localDateTime.plusHours(1));
執(zhí)行上面的代碼就可以看到當(dāng)1987-04-12 01:00:00增加1小時(shí)后,時(shí)間是1987-04-12 02:00:00。
這個(gè)也好理解,因?yàn)長ocalDateTime并沒有包含時(shí)區(qū),1987-04-12 02:00:00這個(gè)夏令時(shí)只是中國的,并不是全球統(tǒng)一的,如果1987-04-12 02:00:00將直接變成1987-04-12 03:00:00放到中國以外的其他國家就是錯(cuò)誤的。
ZonedDateTime zonedDateTime = ZonedDateTime.of(1987, 4, 12, 1, 0, 0, 0, ZoneId.systemDefault()); System.out.println(zonedDateTime); System.out.println(zonedDateTime.plusHours(1));
執(zhí)行上面的代碼可以看到當(dāng)1987-04-12 01:00:00增加1小時(shí)后,時(shí)間變成了是1987-04-12 03:00:00。這個(gè)也就能說明問題了。
同時(shí)從打印結(jié)果也能看到時(shí)區(qū)自動(dòng)從+08:00[Asia/Shanghai]變成了+09:00[Asia/Shanghai]
Instant
Instant表示時(shí)間軸上的一個(gè)瞬時(shí)時(shí)間,簡(jiǎn)單來說就是表示自 1970-01-01T00:00:00Z 紀(jì)元以來的秒數(shù)、毫秒數(shù)等等
ZonedDateTime和Instant都能對(duì)應(yīng)到時(shí)間軸上,所以它們兩個(gè)是可以相互轉(zhuǎn)化的。
Instant instant = zonedDateTime.toInstant(); ZonedDateTime zonedDateTime1 = instant.atZone(zonedDateTime.getZone());
其他一些常用的各種類型之間轉(zhuǎn)化的API
//ZonedDateTime 轉(zhuǎn) Instant Instant instant = ZonedDateTime.now().toInstant(); //獲取UTC毫秒數(shù) long epochMilli = instant.toEpochMilli(); //Instant 轉(zhuǎn) ZonedDateTime ZonedDateTime zonedDateTime = instant.atZone(ZoneId.systemDefault()); //字符串 轉(zhuǎn) ZonedDateTime ZonedDateTime zonedDateTime2 = ZonedDateTime.parse(zonedDateTime.toString()); //基于UTC 偏移的毫秒數(shù) int totalSeconds = zonedDateTime.getOffset().getTotalSeconds(); //Instant 轉(zhuǎn) LocalDateTime LocalDateTime localDateTime = LocalDateTime.ofInstant(instant, ZoneId.systemDefault()); //LocalDateTime 轉(zhuǎn) ZonedDateTime ZonedDateTime zonedDateTime1 = localDateTime.atZone(ZoneId.systemDefault()); ZoneRules zoneRules = ZoneId.systemDefault().getRules(); //判斷是否是夏令時(shí)時(shí)間 boolean daylightSavings = zoneRules.isDaylightSavings(instant); Calendar calendar = Calendar.getInstance(TimeZone.getDefault()); //Calendar 轉(zhuǎn) Instant Instant instant1 = calendar.toInstant(); //Calendar 轉(zhuǎn) ZonedDateTime Calendar now = Calendar.getInstance(); ZonedDateTime zdt = ZonedDateTime.ofInstant(now.toInstant(), ZoneId.systemDefault())); //Date 轉(zhuǎn) Instant Date date = new Date(); Instant inst = date.toInstant(); // Instant 轉(zhuǎn) Date Date newDate = Date.from(inst); //GregorianCalendar 轉(zhuǎn) ZonedDateTime GregorianCalendar cal = GregorianCalendar.from(ZonedDateTime.now()); TimeZone tz = cal.getTimeZone(); ZonedDateTime zdt1 = cal.toZonedDateTime(); //ZonedDateTime 轉(zhuǎn) GregorianCalendar GregorianCalendar newCal = GregorianCalendar.from(zdt1); LocalDateTime ldt = zdt.toLocalDateTime(); LocalDate date2 = zdt.toLocalDate(); LocalTime time2 = zdt.toLocalTime();
更詳細(xì)的資料,還是看官方的文檔吧。https://docs.oracle.com/javase/tutorial/datetime/index.html
總結(jié)
到此這篇關(guān)于Java8中時(shí)間處理的文章就介紹到這了,更多相關(guān)Java8時(shí)間處理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java class文件格式之屬性_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
在本文中, 主要講解了class文件中的一些屬性。 這些屬性可以出現(xiàn)在class文件中的對(duì)個(gè)地方, 用來描述一些其他信息2017-06-06java正則匹配讀取txt文件提取特定開頭和結(jié)尾的字符串
通常我們可以直接通過文件流來讀取txt文件的內(nèi)容,但有時(shí)候也會(huì)遇到問題,下面這篇文章主要給大家介紹了關(guān)于java正則匹配讀取txt文件提取特定開頭和結(jié)尾的字符串的相關(guān)資料,需要的朋友可以參考下2022-11-11springMVC在restful風(fēng)格的性能優(yōu)化方案
這篇文章主要介紹了springMVC在restful風(fēng)格的性能優(yōu)化方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08Java 最優(yōu)二叉樹的哈夫曼算法的簡(jiǎn)單實(shí)現(xiàn)
這篇文章主要介紹了Java 最優(yōu)二叉樹的哈夫曼算法的簡(jiǎn)單實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10java配置變量的解釋,搬運(yùn)他人優(yōu)質(zhì)評(píng)論(推薦)
這篇文章主要介紹了java配置變量,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Java8時(shí)間接口LocalDateTime詳細(xì)用法
最近看別人項(xiàng)目源碼,發(fā)現(xiàn)Java8新的日期時(shí)間API很方便強(qiáng)大,所以整理了這篇文章,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)java的小伙伴們有很好的幫助,需要的朋友可以參考下2021-05-05Java使用HttpClient實(shí)現(xiàn)Post請(qǐng)求實(shí)例
本篇文章主要介紹了Java使用HttpClient實(shí)現(xiàn)Post請(qǐng)求實(shí)例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02Spring使用注解進(jìn)行對(duì)象裝配(DI)的操作
獲取Bean對(duì)象也叫做對(duì)象裝配,就是把對(duì)象取出來放到某個(gè)類中,有時(shí)候也叫對(duì)象注入,這篇文章主要介紹了Spring使用注解進(jìn)行對(duì)象裝配(DI),需要的朋友可以參考下2023-07-07