溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JVM內存的組成及分配

發(fā)布時間:2021-09-18 09:40:50 來源:億速云 閱讀:113 作者:chen 欄目:編程語言

這篇文章主要介紹“JVM內存的組成及分配”,在日常操作中,相信很多人在JVM內存的組成及分配問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”JVM內存的組成及分配”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

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

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

組成圖

JVM內存的組成及分配

◆  方法棧&本地方法棧:

線程創(chuàng)建時產生,方法執(zhí)行時生成棧幀

◆ 方法區(qū)

存儲類的元數據信息 常量等

◆ 堆

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 后調整堆的大小。對象的堆內存由稱為垃圾回收器的自動內存管理系統(tǒng)回收。

JVM內存的組成及分配

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

Eden

存放新生的對象

Survivor Space

有兩個,存放每次垃圾回收后存活的對象
Old GenerationTenured Generation 即圖中的Old Space
主要存放應用程序中生命周期長的存活對象

非堆內存分配

JVM使用-XX:PermSize設置非堆內存初始值,默認是物理內存的1/64;由XX:MaxPermSize設置***非堆內存的大小,默認是物理內存的1/4。

組  成詳  解
Permanent Generation保存虛擬機自己的靜態(tài)(refective)數據
主要存放加載的Class類級別靜態(tài)對象如class本身,method,field等等
permanent generation空間不足會引發(fā)full GC(詳見HotSpot VM GC種類)
Code Cache用于編譯和保存本地代碼(native code)的內存
JVM內部處理或優(yōu)化

JVM內存限制(***值)

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

到此,關于“JVM內存的組成及分配”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注億速云網站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI