这是一个已知问题,当您更新 Java、JDK 或 JRE 时,在 Windows 上 Eclipse 可能无法启动,因为它指向过时的 JDK/JRE 文件夹。修复相对简单,已在 here 等多个线程上讨论并解决或 here .
但我发现这些解决方案缺乏灵 active ,令人不满意。此解决方案建议手动将 eclipse.ini
中的路径修复为类似以下内容:
-vm C:\Program Files\Java\<jdk-version-just-installed>\bin\javaw.exe
这意味着您必须在每次 更新后一次又一次地执行此操作。如果你经常更新 JDK,并且每个人都应该有最新的安全补丁,那就很烦人了。
我希望在智能安装之后,每个 Java 程序都可以开箱即用,而无需任何手动操作;任何低于我认为不满意的解决方案。
我可以想到两种方法:
使用 JAVA_HOME 等环境(系统)变量。
eclipse.ini
可以引用环境变量吗?使用指向最新 JDK 的符号链接(symbolic link)。如果您想知道,是的,带有 NTFS 的 Windows 支持符号链接(symbolic link)。
然而,这两种方式都需要安装程序的一些配合,JAVA_HOME 或符号链接(symbolic link)才能更新为新值。当然是自动的,否则就没有理由把它们放在首位。 如果我错了,请纠正我,但在 Linux 上安装 JDK/JRE 正是这样做的,它提供并更新指向最新 JDK/JRE 的符号链接(symbolic link)。为什么不是 Windows 安装程序?
Java 安装工具中是否有隐藏参数、选项或开关?
如果没有,是否有更好的替代安装工具?
Eclipse 启动器本身可以找到最新的 Java 吗?
是否有更好的 eclipse.ini 参数?
最佳答案
在 eclipse.ini
或命令行中指定 VM 的目的是将其与系统更新隔离开来。例如,过去一些程序安装自己的 JVM 并将其包含在系统 PATH 中一直是一个大问题(Oracle 对此特别糟糕)。所以整个想法是将 Eclipse 与这些类型的更改隔离开来;它不应该关心您的系统上还有哪些其他 JVM,它指的是运行 Eclipse 的“已知”良好 JVM。
另一种方法是将 JVM 直接放置在 Eclipse 安装目录下的名为 jre
的目录中,如文档中所述 here .但是,我个人从来没有这样做过;我发现它既不必要又麻烦。
我所做的可能对您有所帮助的是,不将 JVM 更新安装到名称反射(reflect)实际更新版本的单独目录中。相反,我根据主要 java 版本将 JDK 安装到一致的位置。例如:
/Java/
/JDK/
/1.7/
/bin/
<etc...>
/1.8/
/bin/
<etc...>
这样,在 eclipse.ini
(或任何其他需要引用特定 JVM 的地方)中,我只需使用 /Java/JDK/1.8
即可无论我在该位置安装了多少更新,都可以继续工作。
关于java - 一种使 Eclipse 抵抗 Java 更新的更好方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43094249/