Java記憶體溢位的型別

記憶體溢位通俗理解就是記憶體不夠,通常在執行大型軟體或遊戲時,軟體或遊戲所需要的記憶體遠遠超出了你主機內安裝的記憶體所承受大小,就叫記憶體溢位。下面小編為大家整理了關於Java記憶體溢位的型別,一起來看看吧:

Java記憶體溢位的型別

  1、fMemoryError:PermGenspace

JVM管理兩種型別的Java記憶體,堆和非堆。堆是給開發人員用的上面說的就是,是在JVM啟動時建立;非堆是留給JVM自己用的,用來存放類的資訊的。它和堆不同,執行期內GC不會釋放空間。如果webapp用了大量的第三方jar或者應用有太多的class檔案而恰好MaxPermSize設定較小,超出了也會導致這塊記憶體的佔用過多造成Java記憶體溢位,或者tomcat熱部署時侯不會清理前面載入的環境,只會將context更改為新部署的,非堆存的內容就會越來越多。

PermGenspace的全稱是PermanentGenerationspace,是指記憶體的永久儲存區域,這塊記憶體主要是被JVM存放Class和Meta資訊的,Class在被Loader時就會被放到PermGenspace中,它和存放類例項(Instance)的Heap區域不同,GC(GarbageCollection)不會在主程式執行期對PermGenspace進行清理,所以如果你的應用中有很CLASS的話,就很可能出現PermGenspace錯誤,這種錯誤常見在web伺服器對JSP進行precompile的.時候。如果你的WEBAPP下都用了大量的第三方jar,其大小超過了jvm預設的大小(4M)那麼就會產生此錯誤資訊了。

一個最佳的配置例子:(經過驗證,自從用此配置之後,再未出現過tomcat死掉的情況)

setJAVA_OPTS=-Xms800m

-Xmx800m-XX:PermSize=128M

-XX:MaxNewSize=256m

-XX:MaxPermSize=256m

  2、fMemoryError:Javaheapspace

再來看一下Java記憶體溢位的第二種情況,第一種情況是個補充,主要存在問題就是出現在這個情況中。其預設空間(即-Xms)是實體記憶體的1/64,最大空間(-Xmx)是實體記憶體的1/4。如果記憶體剩餘不到40%,JVM就會增大堆到Xmx設定的值,記憶體剩餘超過70%,JVM就會減小堆到Xms設定的值。所以伺服器的Xmx和Xms設定一般應該設定相同避免每次GC後都要調整虛擬機器堆的大小。假設實體記憶體無限大,那麼JVM記憶體的最大值跟作業系統有關,一般32位機是1.5g到3g之間,而64位的就不會有限制了。

注意:如果Xms超過了Xmx值,或者堆最大值和非堆最大值的總和超過了實體記憶體或者作業系統的最大限制都會引起伺服器啟動不起來。

  垃圾回收GC的角色

JVM呼叫GC的頻度還是很高的,主要兩種情況下進行垃圾回收:

當應用程式執行緒空閒;另一個是java記憶體堆不足時,會不斷呼叫GC,若連續回收都解決不了記憶體堆不足的問題時,就會報outofmemory錯誤。因為這個異常根據系統執行環境決定,所以無法預期它何時出現。根據GC的機制,程式的執行會引起系統執行環境的變化,增加GC的觸發機會。

為了避免這些問題,程式的設計和編寫就應避免垃圾物件的記憶體佔用和GC的開銷。顯示呼叫()只能建議JVM需要在記憶體中對垃圾物件進行回收,但不是必須馬上回收,一個是並不能解決記憶體資源耗空的局面,另外也會增加GC的消耗。