带有JRE 7的Eclipse Juno会在启动时出现问题

时间:2012-11-30 13:23:13

标签: java eclipse jvm jvm-arguments javaw

所解释的问题似乎是一个常见的问题,并且已经提出了不同的解决方案,其中许多解决方案都有效。 One example of this discussion can be found here

我的问题更多是关于为什么而不是如何

我们自己也一直在努力解决这个问题,并发现如果我们使用javaw.exe启动eclipse会出现问题,但如果我们使用jvm.dll调用Eclipse,则不会出现问题。尽管在这两种情况下eclipse.ini仍然相同。

为了解释我的情况,我将使用从命令行使用单个eclipse.exe参数启动-vm的示例。以下是我们正在使用的eclipse.ini

-startup
plugins/org.eclipse.equinox.launcher_1.3.0.v20120522-1813.jar
--launcher.library
plugins/org.eclipse.equinox.launcher.win32.win32.x86_1.1.200.v20120522-1813
--launcher.XXMaxPermSize
256m
-vmargs
-Xms128m
-Xmx1280m
-XX:MaxPermSize=512m
-Dderby.stream.error.field=java.lang.System.err

你可以看到请求分配的内存对于堆(1280m)和PermGen(512m)都是非常多的。如果您无法重现该问题,可以尝试增加内存,直到发生错误。

您可以使用三种不同的命令行:

eclipse.exe -vm ..\jre\bin\javaw.exe
eclipse.exe -vm ..\jre\bin
eclipse.exe -vm ..\jre\bin\client\jvm.dll

只有第一个导致错误(javaw.exe)。其余两个选项成功启动了eclipse。减少eclipse.ini中的内存需求也明显解决了这个问题。

所以我的问题是,为什么javaw.exe在其他两个命令行工作时失败?选择这些不同的路径有什么区别?是否比其他人更严格地执行参数?

环境:Eclipse:3.8-win32,JRE:7u7-win32,Windows 7 x64

1 个答案:

答案 0 :(得分:1)

我无法解释为什么将Eclipse指向可执行文件失败但dll没有,但我可以提供this来解释问题。它的要点是,在Windows上,JVM需要为堆分配一块连续的内存,如果不能,则无法启动。

也许this page将有助于弄清楚为什么指向dll似乎有效。否则,我会问Eclipse Equinox forum