JVM 內存組成

jopen 12年前發布 | 29K 次閱讀 JVM Java開發

java內存組成介紹:堆(Heap)和非堆(Non-heap)內存

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

組成圖

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 內存組成

組成 詳解
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內存管理

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!