我偶尔在Eclipse中运行需要大量内存的任务。因此,当任务正在运行时,JVM会吞噬约2-3GB的RAM,这是可以接受的。但是,一旦JVM占用了该内存,它就不会释放它,我会遇到这样一种情况:堆中使用的内存约为200MB,总堆大小约为3GB,这真的是不希望看到的,因为其他程序需要内存。
我尝试使用Max/MinHeapFreeRatio参数来强制JVM减少未使用内存的消耗。这是我的Eclipse config.ini文件:
但这并没有帮助,我仍然会遇到大量未使用的内存的情况。
我尝试使用Max/MinHeapFreeRatio参数来强制JVM减少未使用内存的消耗。这是我的Eclipse config.ini文件:
-startup
plugins/org.eclipse.equinox.launcher_1.2.0.v20110502.jar
--launcher.library
plugins/org.eclipse.equinox.launcher.win32.win32.x86_64_1.1.100.v20110502
-vm
c:/Program Files/Java/jdk1.6.0_26/bin/javaw.exe
-showlocation
-product
org.eclipse.epp.package.jee.product
--launcher.defaultAction
openFile
--launcher.XXMaxPermSize
256M
-showsplash
org.eclipse.platform
--launcher.XXMaxPermSize
256m
--launcher.defaultAction
openFile
-vmargs
-Duser.name=Michael Nesterenko
-Dosgi.requiredJavaVersion=1.5
-Xms512m
-Xmx4096m
-XX:MinHeapFreeRatio=10
-XX:MaxHeapFreeRatio=30
但这并没有帮助,我仍然会遇到大量未使用的内存的情况。