心情超级不爽啊,一大早来公司本想继续一下昨天的项目,悲催的是双击桌面熟悉的“Eclipse”图标,等了一会居然报错:
【An error has occured.see the log file:你的workspace路径\.log】
打开.log,很多信息。。。巴拉巴拉巴拉。。其中有如下提示:
!MESSAGE An error occurred while automatically activating bundle org.eclipse.equinox.registry (183).
百度的解决办法如下:
方法一:
配置环境变量,JAVA_HOME:jdk的路径,以及在path里添加%JAVA_HOME%\bin,具体环境变量的配置百度一下,很详细的,不在啰嗦!
方法二:
删除工作目录下的.metadata然后再启动eclipse就行了。如果还不行,就重装Eclipse 。 在命令行到eclipse目录下使用 eclipse.exe -clean试一下
方法三:
在使用eclipse时有时会无缘无故出现 !MESSAGE An error occurred while automatically activating bundle org.eclipse.core.resources
!MESSAGE An error occurred while automatically activating bundle org.eclipse.core.resources
今天在做导出操作的一个功能时候,报使用Java程序从数据库中查询大量的数据时出现异常:
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等选项可进行设置。
在百度和谷歌后有了以下的解决方案记录如下:
方案一:
eclipse 有启动参数里设置jvm大小,因为eclipse运行时自己也需要jvm,所以eclipse.ini里设置的jvm大小不是具体某个程序运行时所用jvm的大小,这和具体程序运行的jvm大小无关。
那么怎么才能设置某个程序的jvm大小呢?
(当然控制台运行的话不会存在这个问题,如:java -Xms256m -Xmx1024m classname,这样就可以把当前程序的jvm大小给设定)?
因为eclipse里默认的一个程序的jvm配置为:-Xms8m -Xmx128m,所以我们的处理耗内存比较大时需要手动调整一下,以便不会内存溢出。
具体的设置方法为:
选中被运行的类,点击菜单‘run->run...’,选择(x)=Argument标签页下的vm arguments框里输入
-Xms128m-Xmx512m, 保存运行就ok了
方案二:
这个问题的根源是jvm虚拟机的默认Heap大小是64M,可以通过设置其最大和最小值来实现.设置的方法主要是几个.
1.可以在windows 更改系统环境变量加上JAVA_OPTS=-Xms64m -Xmx512m
2.如果用的tomcat,在windows下,可以在C:\tomcat5.5.9\bin\catalina.bat 中加上:
set JAVA_OPTS=-Xms64m -Xmx256m
位置在: rem Guess CATALINA_HOME if not defined 这行的下面加合适.
3.如果是linux系统
Linux 在{tomcat_home}/bin/catalina.sh的前面,加
set JAVA_OPTS='-Xms64 -Xmx512'