国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java中在時間戳計算的過程中遇到的數據溢出問題

Java中在時間戳計算的過程中遇到的數據溢出問題

2021-12-24 19:56翎野君 Java教程

今天在跑定時任務的過程中,發現有一個任務在設置數據的查詢時間范圍異常,出現了開始時間戳比結束時間戳大的奇怪現象,計算時間戳的代碼大致如下。

背景

Java中在時間戳計算的過程中遇到的數據溢出問題

今天在跑定時任務的過程中,發現有一個任務在設置數據的查詢時間范圍異常,出現了開始時間戳比結束時間戳大的奇怪現象,計算時間戳的代碼大致如下。

  1. package com.lingyejun.authenticator;
  2. public class IntegerTest {
  3. public static void main(String[] args) {
  4. long endTime = System.currentTimeMillis();
  5. long startTime = endTime - 30 * 24 * 60 * 60 * 1000;
  6. System.out.println("end : " + endTime);
  7. System.out.println("start : " + startTime);
  8. }
  9. }

先放出結論:因為java中整數默認是int類型,在計算的過程中30 * 24 * 60 * 60 * 1000計算結果大于Integer.MAX_VALUE,所以出現了數據溢出,從而導致了計算結果不準確的問題。

驗證

我們將上面的代碼稍稍改造一下,方便我們確認定位問題,調整后的代碼如下:

  1. package com.lingyejun.authenticator;
  2. public class IntegerTest {
  3. public static long calcStartTime(long endTime, long minusMills) {
  4. System.out.println("end : " + endTime + " minus mills : " + minusMills);
  5. long startTime = endTime - minusMills;
  6. System.out.println("start: " + startTime);
  7. return startTime;
  8. }
  9. public static void main(String[] args) {
  10. long nowTime = System.currentTimeMillis();
  11. long a = 30 * 24 * 60 * 60 * 1000;
  12. calcStartTime(nowTime, a);
  13. }
  14. }

結果如下:

  1. end : 1560869539864 minus mills : -1702967296
  2. start: 1562572507160

這和我們的預期不一樣,因為30 * 86400000 = 2592000000,但是計算出來卻是:-1702967296。

到這里想必大家都知道原因了,這是因為java中整數的默認類型是整型int,而int的最大值是2147483647,

在代碼中java是先計算右值,再賦值給long變量的。在計算右值的過程中(int型相乘)發生溢出,然后將溢出后截斷的值賦給變量,導致了結果不準確。

將代碼做一下小小的改動,再看一下。

  1. package com.lingyejun.authenticator;
  2. public class IntegerTest {
  3. public static long calcStartTime(long endTime, long minusMills) {
  4. System.out.println("end : " + endTime + " minus mills : " + minusMills);
  5. long startTime = endTime - minusMills;
  6. System.out.println("start: " + startTime);
  7. return startTime;
  8. }
  9. public static void main(String[] args) {
  10. long nowTime = System.currentTimeMillis();
  11. long a = 30 * 24 * 60 * 60 * 1000L;
  12. calcStartTime(nowTime, a);
  13. }
  14. }

結果為

  1. end : 1560869539864 minus mills : 2592000000
  2. start: 1558277539864

似乎這樣應該就沒有什么問題了,但是這樣就真的保險了嗎,如果我要把30調整為24856(Integer.MAX_VALUE / 86400 = 24855),即改為:long a = 24856 * 24 * 60 * 60 * 1000L 那么同樣會出現溢出。

因為java的運算規則從左到右,再與最后一個long型的1000相乘之前就已經溢出,所以結果也不對,正確的方式應該如下:long a = 24856L * 24 * 60 * 60 * 1000。

  1. package com.lingyejun.authenticator;
  2. public class IntegerTest {
  3. public static long calcStartTime(long endTime, long minusMills) {
  4. System.out.println("end : " + endTime + " minus mills : " + minusMills);
  5. long startTime = endTime - minusMills;
  6. System.out.println("start: " + startTime);
  7. return startTime;
  8. }
  9. public static void main(String[] args) {
  10. long a = 30L * 24 * 60 * 60 * 1000;
  11. calcStartTime(nowTime, a);
  12. }
  13. }

原文鏈接:https://www.toutiao.com/a7044145497078088228/

延伸 · 閱讀

精彩推薦
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發現好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發現了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
  • Java教程Java實現搶紅包功能

    Java實現搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java BufferWriter寫文件寫不進去或缺失數據的解決

    Java BufferWriter寫文件寫不進去或缺失數據的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數據的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩中求8032021-07-12
主站蜘蛛池模板: 日韩在线观看视频一区二区三区 | 精品一区二区三区视频 | 久久久久久久久久久蜜桃 | 日韩成人av电影在线观看 | 国产黄色一级大片 | 亚洲淫片 | 欧美午夜一区二区三区 | 在线日韩视频 | 免费a级毛片在线观看 | 久操资源 | 国产黄色在线观看 | 日韩在线一区二区三区 | 国产精品一区二区三区不卡 | 精品视频在线观看 | av黄色在线免费观看 | 免费av一区二区三区 | 国产成人免费视频网站视频社区 | 一区二区免费视频 | 香蕉久久精品视频 | а天堂中文最新一区二区三区 | 黄色片在线| 天堂俺去俺来也www久久婷婷 | 精品国产一区二区三区四 | 自拍亚洲 | 国产高清在线精品一区二区三区 | 久久亚洲国产精品日日av夜夜 | 亚洲国产精品一二三区 | 黄色美女免费 | 免费视频一区 | 国产91久久久 | 九九久久精品 | 色狠狠综合天天综合综合 | 精品国产乱码久久久久久蜜柚 | 日韩中文视频 | 色婷婷久久 | 亚洲成人一区二区三区 | 天天干天天骑 | av网址在线播放 | 国产精品美乳在线观看 | 一区二区三区日本 | 黄p在线看 |