Java堆內存Heap與非堆內存Non-Heap簡介和設置

堆(Heap)和非堆(Non-heap)內存 html

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

 

堆內存分配 數組

JVM初始分配的內存由-Xms指定,默認是物理內存的1/64;JVM最大分配的內存由-Xmx指 定,默認是物理內存的1/4。默認空餘堆內存小於40%時,JVM就會增大堆直到-Xmx的最大限制;空餘堆內存大於70%時,JVM會減小堆直到 -Xms的最小限制。所以服務器通常設置-Xms、-Xmx相等以免在每次GC 後調整堆的大小緩存

例如:
-Xms256m 
-Xmx512m
即初始化堆內存大小爲256MB,最大堆內存爲512MB。服務器

 

非堆內存分配 框架

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

例如:
-XX:PermSize=64m
-XX:PermSize=128m
即設置非堆內存初始值爲64MB,最大非堆內存128MB。測試

 

JVM內存限制(最大值) 優化

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

 

延伸資料:

-Xss<n> 指定線程桟大小 , 如 : -Xss128k, 通常來講,webx框架下的應用須要256K。 若是你的程序有大規模的遞歸行爲,請考慮設置到512K/1M。 這個須要全面的測試才能知道。 不過 256K 已經很大了。 這個參數對性能的影響比較大的。

 

 Java中堆內存和棧內存詳解

http://www.cnblogs.com/whgw/archive/2011/09/29/2194997.html

 

JVM內存參數詳解以及配置調優(一)-基本概念
http://blog.csdn.net/xifeijian/article/details/8316261

 

JVM內存參數詳解以及配置調優(二)-Heap參數
http://blog.csdn.net/xifeijian/article/details/8316267

 

JVM內存參數詳解以及配置調優(三)-garbage collector
http://blog.csdn.net/xifeijian/article/details/8316297

相關文章
相關標籤/搜索