进行插件开发的时候,run as Eclipse Application的时候,报错如下:
Error: Could not create the java virtual machine.
Error:A tatal exception has occurred. Program will exit.
点击确定后,控制台报错如下:
解决办法:
项目上右键→run as → Run Configurations弹出如下设置窗口,选择图中对应的位置:
将 -vm这句话删除即可,在Eclipse运行平台不需要指定虚拟机,此处的标记是因为在Eclipse主程序中的 eclipse.ini文件中加入的。
当运行插件(测试或者调试)的时候,运行环境在主程序Eclipse控制台报错如下:
!ENTRY org.eclipse.ui 4 0 2015-12-01 10:11:44.955 !MESSAGE Unhandled event loop exception Error while logging event loop exception: java.lang.OutOfMemoryError: PermGen space Logging exception: java.lang.OutOfMemoryError: PermGen space
eclipse.ini中其实只是指定了主程序eclipse中的设置,但是运行环境并没有加载到这项设置,所以当插件较多,超出默认的jvm设置的 PermSize限制后,就会报此错误。
扩展:PermGen space的全称是Permanent Generation space,是指内存的永久保存区域OutOfMemoryError: PermGen space从表面上看就是内存益出,解决方法也一定是加大内存。说说为什么会内存益出:这一部分用于存放Class和Meta的信息,Class在被 Load的时候被放入PermGen space区域,它和和存放Instance的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的APP会LOAD很多CLASS的话,就很可能出现PermGen space错误。这种错误常见在web服务器对JSP进行pre compile的时候。
改正方法,在 run.bat 中加入:-Xms256m -Xmx512m -XX:MaxNewSize=256m -XX:MaxPermSize=256m
因为项目中引用了很多的 jar 包,而这些 jar 包中的 class 信息会被 JBoss 的 class loader 加载到 PermGen space 区域,在 JVM 默认的情况下,该部分空间的大小只有 4M,在 jar 包非常多的情况下,显然是不够用的,所以通过 -XX:MaxPermSize=256m 指定最大值后即可解决问题。
另外,如果 heap 内存不足出现 java.lang.OutOfMemoryError: Java heap space 时,可以通过 -Xmx512m 指定最大 heap 内存来解决这样的问题。
解决办法,和问题一修改的位置一样,在编辑区加入如下内容:
-XX:PermSize=256M -XX:MaxPermSize=256M
点击“Applay”,重新run as Eclipse Application,再测试插件,就不会报此错误了。