亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

Java中在時(shí)間戳計(jì)算的過程中遇到的數(shù)據(jù)溢出問題

Bryan / 3292人閱讀

摘要:先放出結(jié)論因?yàn)橹姓麛?shù)默認(rèn)是類型,在計(jì)算的過程中計(jì)算結(jié)果大于,所以出現(xiàn)了數(shù)據(jù)溢出,從而導(dǎo)致了計(jì)算結(jié)果不準(zhǔn)確的問題。在計(jì)算右值的過程中型相乘發(fā)生溢出,然后將溢出后截?cái)嗟闹蒂x給變量,導(dǎo)致了結(jié)果不準(zhǔn)確。

背景

今天在跑定時(shí)任務(wù)的過程中,發(fā)現(xiàn)有一個(gè)任務(wù)在設(shè)置數(shù)據(jù)的查詢時(shí)間范圍異常,出現(xiàn)了開始時(shí)間戳比結(jié)束時(shí)間戳大的奇怪現(xiàn)象,計(jì)算時(shí)間戳的代碼大致如下。

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

先放出結(jié)論:因?yàn)閖ava中整數(shù)默認(rèn)是int類型,在計(jì)算的過程中30 * 24 * 60 * 60 * 1000計(jì)算結(jié)果大于Integer.MAX_VALUE,所以出現(xiàn)了數(shù)據(jù)溢出,從而導(dǎo)致了計(jì)算結(jié)果不準(zhǔn)確的問題。

驗(yàn)證

我們將上面的代碼稍稍改造一下,方便我們確認(rèn)定位問題,調(diào)整后的代碼如下:

package com.lingyejun.authenticator;
 
public class IntegerTest {
 
    public static long calcStartTime(long endTime, long minusMills) {
        System.out.println("end  : " + endTime + " minus mills : " + minusMills);
        long startTime = endTime - minusMills;
        System.out.println("start: " + startTime);
        return startTime;
    }
 
    public static void main(String[] args) {
        long nowTime = System.currentTimeMillis();
        long a = 30 * 24 * 60 * 60 * 1000;
        calcStartTime(nowTime, a);
    }
} 

結(jié)果如下:

end  : 1560869539864 minus mills : -1702967296
start: 1562572507160

這和我們的預(yù)期不一樣,因?yàn)?0 * 86400000 = 2592000000,但是計(jì)算出來卻是:-1702967296。

到這里想必大家都知道原因了,這是因?yàn)閖ava中整數(shù)的默認(rèn)類型是整型int,而int的最大值是2147483647,

在代碼中java是先計(jì)算右值,再賦值給long變量的。在計(jì)算右值的過程中(int型相乘)發(fā)生溢出,然后將溢出后截?cái)嗟闹蒂x給變量,導(dǎo)致了結(jié)果不準(zhǔn)確。

將代碼做一下小小的改動(dòng),再看一下。

package com.lingyejun.authenticator;
 
public class IntegerTest {
 
    public static long calcStartTime(long endTime, long minusMills) {
        System.out.println("end  : " + endTime + " minus mills : " + minusMills);
        long startTime = endTime - minusMills;
        System.out.println("start: " + startTime);
        return startTime;
    }
 
    public static void main(String[] args) {
        long nowTime = System.currentTimeMillis();
        long a = 30 * 24 * 60 * 60 * 1000L;
        calcStartTime(nowTime, a);
    }
}

結(jié)果為

end  : 1560869539864 minus mills : 2592000000
start: 1558277539864

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

因?yàn)閖ava的運(yùn)算規(guī)則從左到右,再與最后一個(gè)long型的1000相乘之前就已經(jīng)溢出,所以結(jié)果也不對(duì),正確的方式應(yīng)該如下:long a = 24856L * 24 * 60 * 60 * 1000

package com.lingyejun.authenticator;
 
public class IntegerTest {
 
    public static long calcStartTime(long endTime, long minusMills) {
        System.out.println("end  : " + endTime + " minus mills : " + minusMills);
        long startTime = endTime - minusMills;
        System.out.println("start: " + startTime);
        return startTime;
    }
 
    public static void main(String[] args) {
        long a = 30L * 24 * 60 * 60 * 1000;
        calcStartTime(nowTime, a);
    }
}

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/77824.html

相關(guān)文章

  • Java內(nèi)存區(qū)域及內(nèi)存溢出

    摘要:直接通過可以造成本機(jī)內(nèi)存溢出。小節(jié)內(nèi)存區(qū)域描述異常程序計(jì)數(shù)器略略略虛擬機(jī)棧存放編譯器可知的各種基本類型,對(duì)象引用和類型每個(gè)線程的棧大小堆存放對(duì)象實(shí)例最大值最小值運(yùn)行時(shí)常亮池存放編譯期生成的字面量和符號(hào)引用,運(yùn)行期也能放入常量池。 堆溢出 Java堆用于存儲(chǔ)對(duì)象實(shí)例,只要不斷地創(chuàng)建對(duì)象,并且保證GC Roots到對(duì)象之間有可達(dá)路徑避免垃圾回收,當(dāng)?shù)竭_(dá)最大堆的容量限制后就會(huì)產(chǎn)生Java.l...

    cheukyin 評(píng)論0 收藏0
  • 系統(tǒng)優(yōu)化怎么做-Tomcat優(yōu)化

    摘要:運(yùn)行模式分種模式一般使用模式效率低對(duì)系統(tǒng)配置有一些比較高的要求確認(rèn)的運(yùn)行模式配置文件關(guān)鍵配置最大線程數(shù)默認(rèn)是最小活躍線程數(shù)默認(rèn)是最大的等待隊(duì)列個(gè)數(shù),超過則請(qǐng)求拒絕默認(rèn)值是,一般不改變。 前言 Tomcat作為Web應(yīng)用的服務(wù)器,目前絕大多數(shù)公司都是用其作為應(yīng)用服務(wù)器的,應(yīng)用服務(wù)器的執(zhí)行效率會(huì)影響系統(tǒng)執(zhí)行,這里會(huì)講Tomcat怎樣進(jìn)行配置能提高處理性能。另外必須提到對(duì)應(yīng)的JVM參數(shù)的優(yōu)化...

    gghyoo 評(píng)論0 收藏0
  • Java虛擬機(jī):Java自動(dòng)內(nèi)存管理和回收機(jī)制

    摘要:所以我們提到的內(nèi)存回收大都是指堆內(nèi)存的回收。根據(jù)堆內(nèi)存對(duì)對(duì)象的代的劃分我們對(duì)堆內(nèi)存有這樣劃分各版本和種類的垃圾回收器各有其用武之地,配合使用它們得到最好的效果十分重要。 這篇文章的素材來自周志明的《深入理解Java虛擬機(jī)》。作為Java開發(fā)人員,一定程度了解JVM虛擬機(jī)的的運(yùn)作方式非常重要,本文就一些簡(jiǎn)單的虛擬機(jī)的相關(guān)概念和運(yùn)作機(jī)制展開我自己的學(xué)習(xí)過程。 虛擬機(jī)內(nèi)存分區(qū) java虛擬機(jī)...

    xuxueli 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<