Java 9编译器中的--release标志是什么?

问题描述 投票:51回答:2

Java 9的javac有一个新的标志--release

> javac --help
...

--release <release>
    Compile for a specific VM version. Supported targets: 6, 7, 8, 9

它与-source-target旗帜有什么不同?这只是-source X -target X的捷径吗?

java javac java-9
2个回答
71
投票

不完全是。

JEP 247: Compile for Older Platform Versions定义了这个新的命令行选项,--release

我们定义了一个新的命令行选项--release,它自动配置编译器以生成将链接到给定平台版本的实现的类文件。对于在javac中预定义的平台,--release N相当于-source N -target N -bootclasspath <bootclasspath-from-N>。 (强调我的)

所以不,它不等于-source N -target N。添加的原因在“动机”部分中说明:

javac提供了两个命令行选项-source-target,它们可以分别用于选择编译器接受的Java语言版本及其生成的类文件的版本。但是,默认情况下,javac会针对最新版本的平台API进行编译。因此,编译的程序可能会意外地使用仅在当前版本的平台中可用的API。无论传递给-source-target的值如何,此类程序都无法在较旧版本的平台上运行。选项。这是一个长期的可用性痛点,因为用户希望通过使用这些选项,他们将获得可以在指定平台版本上运行的类文件。

简而言之,指定源和目标选项不足以进行交叉编译。由于javac默认情况下会针对最新的平台API进行编译,因此无法保证它们能够在旧版本上运行。您还需要指定与旧版本对应的-bootclasspath选项以正确交叉编译。这将包括要编译的正确API版本并允许在旧版本上执行。由于经常被遗忘,因此决定添加一个命令行选项,该选项执行所有必要的操作以正确交叉编译。

进一步阅读in the mailing listOracle Docs。原始的bug被提交here。请注意,由于此选项的集成,JDK构建已捆绑了旧版本的平台API的描述,在“风险和假设”部分中提到。这意味着您无需在计算机上安装旧版本即可进行交叉编译。


16
投票

--release X不仅仅是-source X -target X的捷径,因为-source-target不足以安全地编译到旧版本。您还需要设置一个-bootclasspath标志,该标志必须与旧版本相对应(并且这个标志经常被遗忘)。因此,在Java 9中他们制作了一个--release标志,它取代了三个标志:-source-target-bootclasspath

所以,这是编译Java 1.7的一个例子:

javac --release 7 <source files>

请注意,您甚至不需要在计算机上安装JDK 7。 JDK 9已包含所需信息,以防止意外链接到JDK 7中不存在的符号。

© www.soinside.com 2019 - 2024. All rights reserved.