今天開始實戰Java虛擬機之五“開啟JIT編譯”
總計有5個系列
- 實戰Java虛擬機之一“堆溢出處理”
- 實戰Java虛擬機之二“虛擬機的工作模式”
- 實戰Java虛擬機之三“G1的新生代GC”
- 實戰Java虛擬機之四“禁用System.gc()”
- 實戰Java虛擬機之五“開啟JIT編譯”
Java虛擬機有3種執行方式,分別是解釋執行、混合模式和編譯執行,默認情況下處於混合模式中。使用命令行java –version可以查看虛擬機的執行模式:
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”就表示混合模式。在混合模式中,部分函數會被解釋執行,部分可能被編譯執行。虛擬機決定函數是否需要編譯執行的依據是判斷該函數,是否為熱點代碼。如果函數的調用頻率很高,被反復使用,那么就會被認為是熱點,熱點代碼就會被編譯執行。
解釋執行模式表示全部代碼均解釋執行,不做任何JIT編譯,可以使用參數-Xint來開啟解釋執行模式:
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