在運行java桌面應用程序的時候,有時候會由於jvm內存過小,從而內存溢出,程序崩潰。
但是經過修改 eclipse.ini 中的參數,來實現修改jvm的內存大小。
-vmargs
-Xms128M
-Xmx512M
-XX:PermSize=64M
-XX:MaxPermSize=128M
這裏有幾個問題:
1. 各個參數的含義什麼?
2. 爲何有的機器我將-Xmx和-XX:MaxPermSize都設置爲512M以後Eclipse能夠啓動,而有些機器沒法啓動?
3. 爲什麼將上面的參數寫入到eclipse.ini文件Eclipse沒有執行對應的設置?
1. 各個參數的含義什麼?
參數中-vmargs的意思是設置JVM參數,因此後面的其實都是JVM的參數了,咱們首先了解一下JVM內存管理的機制,而後再解釋每一個參數表明的含義。
堆(Heap)和非堆(Non-heap)內存
按照官方的說法:「Java 虛擬機具備一個堆,堆是運行時數據區域,全部類實例和數組的內存均今後處分配。堆是在 Java 虛擬機啓動時建立的。」「在JVM中堆以外的內存稱爲非堆內存(Non-heap memory)」。能夠看出JVM主要管理兩種類型的內存:堆和非堆。簡單來講堆就是Java代碼可及的內存,是留給開發人員使用的;非堆就是JVM留給本身用的,因此方法區、JVM內部處理或優化所需的內存(如JIT編譯後的代碼緩存)、每一個類結構(如運行時常數池、字段和方法數據)以及方法和構造方法的代碼都在非堆內存中。
堆內存分配
JVM初始分配的內存由-Xms指定,默認是物理內存的1/64;JVM最大分配的內存由-Xmx指定,默認是物理內存的1/4。默認空餘堆內存小於40%時,JVM就會增大堆直到-Xmx的最大限制;空餘堆內存大於70%時,JVM會減小堆直到-Xms的最小限制。所以服務器通常設置-Xms、-Xmx相等以免在每次GC 後調整堆的大小。
非堆內存分配
JVM使用-XX:PermSize設置非堆內存初始值,默認是物理內存的1/64;由XX:MaxPermSize設置最大非堆內存的大小,默認是物理內存的1/4。
JVM內存限制(最大值)
首先JVM內存限制於實際的最大物理內存(廢話!呵呵),假設物理內存無限大的話,JVM內存的最大值跟操做系統有很大的關係。簡單的說就32位處理器雖然可控內存空間有4GB,可是具體的操做系統會給一個限制,這個限制通常是2GB-3GB(通常來講Windows系統下爲1.5G-2G,Linux系統下爲2G-3G),而64bit以上的處理器就不會有限制了。
2. 爲何有的機器我將-Xmx和-XX:MaxPermSize都設置爲512M以後Eclipse能夠啓動,而有些機器沒法啓動?
經過上面對JVM內存管理的介紹咱們已經瞭解到JVM內存包含兩種:堆內存和非堆內存,另外JVM最大內存首先取決於實際的物理內存和操做系統。因此說設置VM參數致使程序沒法啓動主要有如下幾種緣由:
1) 參數中-Xms的值大於-Xmx,或者-XX:PermSize的值大於-XX:MaxPermSize;
2) -Xmx的值和-XX:MaxPermSize的總和超過了JVM內存的最大限制,好比當前操做系統最大內存限制,或者實際的物理內存等等。說到實際物理內存這裏須要說明一點的是,若是你的內存是1024MB,但實際系統中用到的並不多是1024MB,由於有一部分被硬件佔用了。
3. 爲什麼將上面的參數寫入到eclipse.ini文件Eclipse沒有執行對應的設置?
那爲何一樣的參數在快捷方式或者命令行中有效而在eclipse.ini文件中是無效的呢?這是由於咱們沒有遵照eclipse.ini文件的設置規則:
參數形如「項 值」這種形式,中間有空格的須要換行書寫,若是值中有空格的須要用雙引號包括起來。好比咱們使用-vm C:\Java\jre1.6.0\bin\javaw.exe參數設置虛擬機,在eclipse.ini文件中要寫成這樣:
1 -vm
2 C:\Java\jre1.6.0\bin\javaw.exe
按照上面所說的,最後參數在eclipse.ini中能夠寫成這個樣子:
3 -vmargs
4 -Xms128M
5 -Xmx512M
6 -XX:PermSize=64M
7 -XX:MaxPermSize=128M
實際運行的結果能夠經過Eclipse中「Help」-「About Eclipse SDK」窗口裏面的「Configuration Details」按鈕進行查看。
另外須要說明的是,Eclipse壓縮包中自帶的eclipse.ini文件內容是這樣的:
8 -showsplash
9 org.eclipse.platform
10 --launcher.XXMaxPermSize
11 256m
12 -vmargs
13 -Xms40m
14 -Xmx256m
其中–launcher.XXMaxPermSize(注意最前面是兩個鏈接線)跟-XX:MaxPermSize參數的含義基本是同樣的,我以爲惟一的區別就是前者是eclipse.exe啓動的時候設置的參數,然後者是eclipse所使用的JVM中的參數。其實兩者設置一個就能夠了,因此這裏能夠把–launcher.XXMaxPermSize和下一行使用#註釋掉。
一樣,經過eclipse設置來修改此參數:
Window->Preferences->Java->Installed JREs 雙擊jre,java