使用Maven设置Java编译器的-source和-target不起作用

His*_*His 19 java maven

我已经设置了我的pom文件,要求Maven使用sourcetargetconfig参数将我的源代码编译为兼容版本1.5 .这是我的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</groupId>
  <artifactId>user</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <name>test</name>
   <build>
    <plugins>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <configuration>
          <source>1.5</source>
          <target>1.5</target>
        </configuration>
      </plugin>
    </plugins>
  </build>
</project>
Run Code Online (Sandbox Code Playgroud)

我有一个像这样的简单主类:

package com.user;
public class Test
{
    public static void main(String[] argv)
    {
        System.out.println("".isEmpty());
    }
}
Run Code Online (Sandbox Code Playgroud)

String#isEmpty()从Java 1.6开始引入.但是,编译我的代码与mvn compile工作,虽然我会期望它失败,因为我已经设置Maven将我的代码编译为Java 1.5并String#isEmpty在Java 1.6中引入.任何人都可以建议我可能做错了什么?在编译时强制Maven使用特定Java版本的正确方法是什么?

有关信息,我使用Apache Maven 2.2.1和javac 1.6.0_19.

谢谢.

Mik*_*ell 28

编译器插件页面底部的注释:

仅设置目标选项并不能保证您的代码实际上在具有指定版本的JRE上运行.这种陷阱是无意中使用的API,它只存在于以后的JRE中,这会使您的代码在运行时因链接错误而失败.要避免此问题,您可以配置编译器的引导类路径以匹配目标JRE,或使用Animal Sniffer Maven插件验证您的代码不使用非预期的API

这意味着虽然您正在生成1.5级字节码,但您仍然可以(无意中)调用1.6 API方法.要标记这些invalide API调用,请使用他们提到的插件.


Col*_*inD 8

如果您希望找不到Java,则需要使用较低版本的Java进行编译String.isEmpty().源级别控制您可以使用和不能使用的语言级功能,例如@Override需要使用源级别1.6进行编译的接口.目标级别控制编译产生的字节码的兼容性.既没有与可用的API有任何关系...这些都基于您在构建时使用的类路径,在您的情况下包括Java 1.6.