查漏補缺,JVM系列:(JVM內存組成及分配)

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

按照官方的說法:「Java 虛擬機具備一個堆,堆是運行時數據區域,全部類實例和數組的內存均今後處分配。堆是在 Java 虛擬機啓動時建立的。」「在JVM中堆以外的內存稱爲非堆內存(Non-heap memory)」。能夠看出JVM主要管理兩種類型的內存:堆和非堆。簡單來講堆就是Java代碼可及的內存,是留給開發人員使用的;非堆就是JVM留給 本身用的,因此方法區、JVM內部處理或優化所需的內存(如JIT編譯後的代碼緩存)、每一個類結構(如運行時常數池、字段和方法數據)以及方法和構造方法 的代碼都在非堆內存中。數組

組成圖緩存

  1. 方法棧&本地方法棧:
  2. 線程建立時產生,方法執行時生成棧幀
  3. 方法區
  4. 存儲類的元數據信息 常量等
  5. java代碼中全部的new操做
  6. native Memory(C heap)
  7. Direct Bytebuffer JNI Compile GC;

堆內存分配服務器

JVM初始分配的內存由-Xms指定,默認是物理內存的1/64;JVM最大分配的內存由-Xmx指 定,默認是物理內存的1/4。默認空餘堆內存小於40%時,JVM就會增大堆直到-Xmx的最大限制;空餘堆內存大於70%時,JVM會減小堆直到 -Xms的最小限制。所以服務器通常設置-Xms、-Xmx相等以免在每次GC 後調整堆的大小。對象的堆內存由稱爲垃圾回收器的自動內存管理系統回收。點擊「領取Java架構資料」架構

組成詳解Young Generation即圖中的Eden + From Space + To SpaceEden優化

存放新生的對象Survivor Space操作系統

有兩個,存放每次垃圾回收後存活的對象Old GenerationTenured Generation 即圖中的Old Space線程

主要存放應用程序中生命週期長的存活對象code

非堆內存分配對象

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)的內存 「領取Java架構資料」

JVM內部處理或優化

JVM內存限制(最大值)

JVM內存的最大值跟操做系統有很大的關係。簡單的說就32位處理器雖然 可控內存空間有4GB,可是具體的操做系統會給一個限制,這個限制通常是2GB-3GB(通常來講Windows系統下爲1.5G-2G,Linux系統 下爲2G-3G),而64bit以上的處理器就不會有限制了。

相關文章
相關標籤/搜索