【Java】實戰Java虛擬機之五「開啓JIT編譯」

今天開始實戰Java虛擬機之五「開啓JIT編譯」java

總計有5個系列jvm

     Java虛擬機有3種執行方式,分別是解釋執行、混合模式和編譯執行,默認狀況下處於混合模式中。使用命令行java –version能夠查看虛擬機的執行模式:code

C:\Users\Administrator>java -version
java version "1.7.0_13"
Java(TM) SE Runtime Environment (build1.7.0_13-b20)
Java HotSpot(TM) 64-Bit Server VM (build 23.7-b01,mixed mode)


    上面輸出的「mixed mode」就表示混合模式。在混合模式中,部分函數會被解釋執行,部分可能被編譯執行。虛擬機決定函數是否須要編譯執行的依據是判斷該函數,是否爲熱點代碼。若是函數的調用頻率很高,被反覆使用,那麼就會被認爲是熱點,熱點代碼就會被編譯執行。orm

    解釋執行模式表示所有代碼均解釋執行,不作任何JIT編譯,能夠使用參數-Xint來開啓解釋執行模式:get

C:\Users\Administrator>java -Xint -version
java version "1.7.0_13"
Java(TM) SE Runtime Environment (build1.7.0_13-b20)
Java HotSpot(TM) 64-Bit Server VM (build 23.7-b01,interpreted mode)

   編譯執行模式和解釋執行模式相反,對於全部的函數,不管是不是熱點代碼,都會被編譯執行,使用參數-Xcomp能夠設置爲編譯模式:

C:\Users\Administrator>java -Xcomp -version
java version "1.7.0_13"
Java(TM) SE Runtime Environment (build1.7.0_13-b20)
Java HotSpot(TM) 64-Bit Server VM (build 23.7-b01,compiled mode)


通常來講,編譯模式的執行效率會遠遠高於解釋模式。更多的示例參考《實戰Java虛擬機》一書。

【示例11-36】下面的代碼不停計算圓周率的數值,並給出了運行的耗時:

public static double calcPi(){
         doublere=0;
         for(inti=1;i<10000;i++){
                   re+=((i&1)==0?-1:1)*1.0/(2*i-1);
         }
         returnre*4;
}
public static void main(String[] args) {
         longb=System.currentTimeMillis();
         for(inti=0;i<10000;i++)
                   calcPi();            
         longe=System.currentTimeMillis();
         System.out.println("spend:"+(e-b)+"ms");
}


使用虛擬機參數-Xint運行以上代碼,輸出:

spend:2794ms

使用虛擬機參數-Xcomp運行以上代碼,輸出:

spend:1082ms


很明顯,在本例中使用編譯運行要比解釋運行快大約3倍。



25612fm立體圖

《實戰java虛擬機》一書Q交流羣:397196583

相關文章
相關標籤/搜索