今天開始實戰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倍。
《實戰java虛擬機》一書Q交流羣:397196583