JVM基礎(chǔ):JVM內(nèi)存組成及分配
java內(nèi)存組成介紹:堆(Heap)和非堆(Non-heap)內(nèi)存
按照官方的說法:“Java 虛擬機具有一個堆,堆是運行時數(shù)據(jù)區(qū)域,所有類實例和數(shù)組的內(nèi)存均從此處分配。堆是在 Java 虛擬機啟動時創(chuàng)建的。”“在JVM中堆之外的內(nèi)存稱為非堆內(nèi)存(Non-heap memory)”??梢钥闯鯦VM主要管理兩種類型的內(nèi)存:堆和非堆。簡單來說堆就是Java代碼可及的內(nèi)存,是留給開發(fā)人員使用的;非堆就是JVM留給 自己用的,所以方法區(qū)、JVM內(nèi)部處理或優(yōu)化所需的內(nèi)存(如JIT編譯后的代碼緩存)、每個類結(jié)構(gòu)(如運行時常數(shù)池、字段和方法數(shù)據(jù))以及方法和構(gòu)造方法 的代碼都在非堆內(nèi)存中。
組成圖
◆ 方法棧&本地方法棧:
線程創(chuàng)建時產(chǎn)生,方法執(zhí)行時生成棧幀
◆ 方法區(qū)
存儲類的元數(shù)據(jù)信息 常量等
◆ 堆
java代碼中所有的new操作
◆ native Memory(C heap)
Direct Bytebuffer JNI Compile GC;
堆內(nèi)存分配
JVM初始分配的內(nèi)存由-Xms指定,默認是物理內(nèi)存的1/64;JVM***分配的內(nèi)存由-Xmx指 定,默認是物理內(nèi)存的1/4。默認空余堆內(nèi)存小于40%時,JVM就會增大堆直到-Xmx的***限制;空余堆內(nèi)存大于70%時,JVM會減少堆直到 -Xms的最小限制。因此服務(wù)器一般設(shè)置-Xms、-Xmx相等以避免在每次GC 后調(diào)整堆的大小。對象的堆內(nèi)存由稱為垃圾回收器的自動內(nèi)存管理系統(tǒng)回收。
組 成 | 詳 解 |
---|---|
Young Generation | 即圖中的Eden + From Space + To Space |
Eden |
存放新生的對象 |
Survivor Space |
有兩個,存放每次垃圾回收后存活的對象 |
Old Generation | Tenured Generation 即圖中的Old Space 主要存放應(yīng)用程序中生命周期長的存活對象 |
非堆內(nèi)存分配
JVM使用-XX:PermSize設(shè)置非堆內(nèi)存初始值,默認是物理內(nèi)存的1/64;由XX:MaxPermSize設(shè)置***非堆內(nèi)存的大小,默認是物理內(nèi)存的1/4。
組 成 | 詳 解 |
---|---|
Permanent Generation | 保存虛擬機自己的靜態(tài)(refective)數(shù)據(jù) 主要存放加載的Class類級別靜態(tài)對象如class本身,method,field等等 permanent generation空間不足會引發(fā)full GC(詳見HotSpot VM GC種類) |
Code Cache | 用于編譯和保存本地代碼(native code)的內(nèi)存 JVM內(nèi)部處理或優(yōu)化 |
JVM內(nèi)存限制(***值)
JVM內(nèi)存的***值跟操作系統(tǒng)有很大的關(guān)系。簡單的說就32位處理器雖然 可控內(nèi)存空間有4GB,但是具體的操作系統(tǒng)會給一個限制,這個限制一般是2GB-3GB(一般來說Windows系統(tǒng)下為1.5G-2G,Linux系統(tǒng) 下為2G-3G),而64bit以上的處理器就不會有限制了。
原文鏈接:http://www.cnblogs.com/redcreen/archive/2011/05/04/2036387.html
【系列文章】