天天看點

JVM系列一:JVM記憶體組成及配置設定 JVM系列一:JVM記憶體組成及配置設定

JVM系列一:JVM記憶體組成及配置設定

java記憶體組成介紹:堆(Heap)和非堆(Non-heap)記憶體

       按照官方的說法:“Java 虛拟機具有一個堆,堆是運作時資料區域,所有類執行個體和數組的記憶體均從此處配置設定。堆是在 Java 虛拟機啟動時建立的。”“在JVM中堆之外的記憶體稱為非堆記憶體(Non-heap memory)”。可以看出JVM主要管理兩種類型的記憶體:堆和非堆。簡單來說堆就是Java代碼可及的記憶體,是留給開發人員使用的;非堆就是JVM留給 自己用的,是以方法區、JVM内部處理或優化所需的記憶體(如JIT編譯後的代碼緩存)、每個類結構(如運作時常數池、字段和方法資料)以及方法和構造方法 的代碼都在非堆記憶體中。

組成圖

JVM系列一:JVM記憶體組成及配置設定 JVM系列一:JVM記憶體組成及配置設定
  • 方法棧&本地方法棧:

    線程建立時産生,方法執行時生成棧幀

  • 方法區

    存儲類的中繼資料資訊 常量等

  • java代碼中所有的new操作

  • native Memory(C heap)

    Direct Bytebuffer JNI Compile GC;

堆記憶體配置設定

       JVM初始配置設定的記憶體由-Xms指定,預設是實體記憶體的1/64;JVM最大配置設定的記憶體由-Xmx指 定,預設是實體記憶體的1/4。預設空餘堆記憶體小于40%時,JVM就會增大堆直到-Xmx的最大限制;空餘堆記憶體大于70%時,JVM會減少堆直到 -Xms的最小限制。是以伺服器一般設定-Xms、-Xmx相等以避免在每次GC 後調整堆的大小。對象的堆記憶體由稱為垃圾回收器的自動記憶體管理系統回收。

JVM系列一:JVM記憶體組成及配置設定 JVM系列一:JVM記憶體組成及配置設定
組成 詳解
Young Generation 即圖中的Eden + From Space + To Space
Eden 存放新生的對象
Survivor Space 有兩個,存放每次垃圾回收後存活的對象
Old Generation

Tenured Generation 即圖中的Old Space 

主要存放應用程式中生命周期長的存活對象

      非堆記憶體配置設定

      JVM使用-XX:PermSize設定非堆記憶體初始值,預設是實體記憶體的1/64;由XX:MaxPermSize設定最大非堆記憶體的大小,預設是實體記憶體的1/4。

組成 詳解
Permanent Generation

儲存虛拟機自己的靜态(refective)資料

主要存放加載的Class類級别靜态對象如class本身,method,field等等

permanent generation空間不足會引發full GC(詳見HotSpot VM GC種類)

Code Cache

用于編譯和儲存本地代碼(native code)的記憶體

JVM内部處理或優化

      JVM記憶體限制(最大值)

      JVM記憶體的最大值跟作業系統有很大的關系。簡單的說就32位處理器雖然 可控記憶體空間有4GB,但是具體的作業系統會給一個限制,這個限制一般是2GB-3GB(一般來說Windows系統下為1.5G-2G,Linux系統 下為2G-3G),而64bit以上的處理器就不會有限制了。

相關文章:http://www.cnblogs.com/redcreen/tag/jvm/

參考文章:

http://blog.csdn.net/softwave/archive/2011/03/10/6238747.aspx

http://www.7dtest.com/site/html/74/t-4574.html

Sun JDK 1.6記憶體管理

轉自: http://www.cnblogs.com/redcreen/archive/2011/05/04/2036387.html