Maven Java编译器版本
Maven使用的默认Java编译器版本是Java 1.5. 自从2004年发布Java 5以来,为什么仍然使用默认的Java编译器版本是个好问题。要使Maven使用较新版本的Java编译器编译Java代码,我们需要在项目的POM中明确指定Java编译器。文件(pom.xml
)。
确切指定Java编译器版本的方式取决于我们使用的是Java 8或者更早版本,还是Java 9或者更高版本。从Java 9开始,Java获得了一些模块,这些模块在短期内会使编译有些复杂,但从长期来看应该会有所帮助。
适用于Java 8和更早版本的Maven Java编译器
从Java 8和更早版本开始,有两种方法可以在Maven POM文件中设置Java编译器版本:
- 通过Maven Java编译器属性。
- 通过Maven Java编译器"插件"。
以下各节将说明这两种在Maven中设置Java编译器版本的方法。
Maven Java编译器属性
在Maven POM文件中设置Java编译器版本的第一种,最新和最简单的方法是通过Maven Java编译器属性。这是Maven Java编译器属性的外观:
<properties> <maven.compiler.target>1.8</maven.compiler.target> <maven.compiler.source>1.8</maven.compiler.source> </properties>
这些属性必须包含在POM文件的properties
元素中。通常,我的POM文件中的最后一个元素是" properties"元素。
Maven Java编译器插件
通过Maven Java编译器插件在Maven POM文件中设置Java编译器版本的第二个,最古老且更冗长的内容。 Maven Java编译器插件的配置如下所示:
<build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.6.1</version> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build>
带有Java编译器版本集的完整Maven POM文件
为方便起见,这是使用上述两种机制设置的Java编译器版本的完整Maven POM文件。请注意,POM文件中仅应使用一种机制。该示例仅显示了两个示例,因此我们可以看到它们将在POM文件中放置的位置。
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" > <modelVersion>4.0.0</modelVersion> <groupId>com.nanosai</groupId> <artifactId>grid-ops</artifactId> <version>0.8.0</version> <packaging>jar</packaging> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.6.1</version> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build> <properties> <project.build.sourceEncoding> UTF-8 </project.build.sourceEncoding> <maven.compiler.target>1.8</maven.compiler.target> <maven.compiler.source>1.8</maven.compiler.source> </properties> </project>
适用于Java 9及更高版本的Maven Java编译器
对于Java 9和更高版本,我们需要使用Java编译器插件的细微变化。我们需要使用release属性来代替source和target属性。这是一个Maven Java编译器插件具有release属性的示例:
<plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.0</version> <configuration> <release>11</release> </configuration> </plugin>
本示例在release属性中将Java版本设置为11. 在撰写本文时,Java 11是Java的最新长期支持(LTS)版本。
还要注意,Maven Java编译器插件的版本已从3.6.1更改为3.8.0。
请记住,升级到Java 9+时,我们很可能会遇到更多问题,例如确保Java项目使用的所有Maven插件和依赖项也与Java 9+兼容。但是,有关如何完成此操作的详细信息超出了本Maven Java编译器教程的范围。
启用预览函数
某些更高版本的Java版本(至少Java 10、12和13)具有一些预览函数。预览中的函数是Java SDK团队已实现但尚未确定是否应长期保留在Java SDK中的函数。默认情况下,Java SDK中未启用这些函数。要使用它们,必须显式启用它们。要在Maven POM文件中启用Java预览函数,如下所示,将CompilerArgs元素插入到编译器配置中:
<plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.0</version> <configuration> <release>11</release> <compilerArgs>--enable-preview</compilerArgs> </configuration> </plugin>