问题:

在eclipse中执行java程序。去重100多万的数据,报例如以下错误:

java.lang.OutOfMemoryError: Java heap space


异常原因:

在JVM中假设98%的时间是用于GC且可用的 Heap size 不足2%的时候将抛出此异常信息。

JVM堆的设置是指java程序执行过程中JVM能够调配使用的内存空间的设置。

JVM在启动的时候会自己主动设置Heap size的值,其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。能够利用JVM提供的-Xmn -Xms -Xmx等选项可进行设置。

比方:java -Xmx3550m -Xms3550m -Xmn2g -Xss128k
-Xmx3550m:设置JVM最大可用内存为3550m。
-Xms3550m:设置JVM初始内存为3550m。

此值能够设置与-Xmx同样,以避免每次垃圾回收完毕后JVM又一次分配内存。

-Xmn2g:设置年轻代大小为2G。

整个JVM内存大小=年轻代大小 + 年老代大小 + 持久代大小。持久代一般固定大小为64m.整个堆大小=年轻代大小 + 年老代大小.所以增大年轻代后。将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。
-Xss128k:设置每一个线程的堆栈大小。JDK5.0以后每一个线程堆栈大小为1M,曾经每一个线程堆栈大小为256K。

更具应用的线程所需内存大小进行调整。在同样物理内存下。减小这个值能生成很多其它的线程。可是操作系统对一个进程内的线程数还是有限制的,不能无限生成,经验值在3000~5000左右。


解决方式:
方案一:

eclipse 启动參数里能够设置jvm大小,由于eclipse执行时也须要jvm。eclipse.ini里设置的jvm大小不是详细某个程序执行时所用jvm的大小,对所有程序有效。

 
那么怎么才干设置某个程序的jvm大小呢?
(当然控制台执行的话不会存在这个问题,如:java -Xms256m -Xmx1024m classname,这样就能够把当前程序的jvm大小给设定) 
eclipse默认的jvm配置为:-Xms8m -Xmx128m,在内存不足时须要手动调整一下。
详细的设置方法为:
选中被执行的类。点击菜单‘run->run configurations’,选择(x)=Argument标签页下的vm arguments框里输入

-Xms64m-Xmx512m(依据你物理内存的大小调整),保存执行就ok了


方案二:

这个问题的根源是jvm虚拟机默认Heap大小是64M。能够通过设置其最大和最小值来实现。

设置的方法主要有下面:
1.能够在windows 更改系统环境变量加上JAVA_OPTS=-Xms64m -Xmx512m。

2.假设用的tomcat,

1)在windows下,能够在C:\tomcat5.5.9\bin\catalina.bat 中加上:set JAVA_OPTS=-Xms64m -Xmx256m。

位置在: rem Guess CATALINA_HOME if not defined 这行的以下加合适。

2)在linux下,在{tomcat_home}/bin/catalina.sh的前面,加 set JAVA_OPTS='-Xms64 -Xmx512'。