深刻理解JVM結構

JVM結構探究----

1.JVM結構示意圖

2.JVM運行時數據區

1)程序計數器(Program Counter Register)java

  程序計數器是用於存儲每一個線程下一步將執行的JVM指令,如該方法爲native的,則程序計數器中不存儲任何信息數組

2)JVM棧(JVM Stack)性能

  JVM棧是線程私有的,每一個線程建立的同時都會建立JVM棧,JVM棧中存放的爲當前線程中局部基本類型的變量(java中定義的八種基本類型:boolean、char、byte、short、int、long、float、double)、部分的返回結果以及Stack Frame,非基本類型的對象在JVM棧上僅存放一個指向堆上的地址spa

3)堆(heap)線程

  它是JVM用來存儲對象實例以及數組值的區域,能夠認爲Java中全部經過new建立的對象的內存都在此分配,Heap中的對象的內存須要等待GC進行回收。對象

  (1)堆是JVM中全部線程共享的,所以在其上進行對象內存的分配均須要進行加鎖,這也致使了new對象的開銷是比較大的blog

  (2)Sun Hotspot JVM爲了提高對象內存分配的效率,對於所建立的線程都會分配一塊獨立的空間TLAB(Thread Local Allocation Buffer),其大小由JVM根據運行的狀況計算而得,在TLAB上分配對象時不須要加鎖,所以JVM在給線程的對象分配內存時會盡可能的在TLAB上分配,在這種狀況下JVM中分配對象內存的性能和C基本是同樣高效的,但若是對象過大的話則仍然是直接使用堆空間分配內存

  (3)TLAB僅做用於新生代的Eden Space,所以在編寫Java程序時,一般多個小的對象比大的對象分配起來更加高效。開發

4)方法區(Method Area)字符串

  (1)在Sun JDK中這塊區域對應的爲PermanetGeneration,又稱爲持久代。

  (2)方法區域存放了所加載的類的信息(名稱、修飾符等)、類中的靜態變量、類中定義爲final類型的常量、類中的Field信息、類中的方法信息,當開發人員在程序中經過Class對象中的getName、isInterface等方法來獲取信息時,這些數據都來源於方法區域,同時方法區域也是全局共享的,在必定的條件下它也會被GC,當方法區域須要使用的內存超過其容許的大小時,會拋出OutOfMemory的錯誤信息。

5)本地方法棧(Native Method Stacks)

  JVM採用本地方法棧來支持native方法的執行,此區域用於存儲每一個native方法調用的狀態。

6)運行時常量池(Runtime Constant Pool)

  存放的爲類中的固定的常量信息、方法和Field的引用信息等,其空間從方法區域中分配。JVM在加載類時會爲每一個class分配一個獨立的常量池,可是運行時常量池中的字符串常量池是全局共享的

相關文章
相關標籤/搜索