Установка -source и -target компилятора Java с Maven - не работает

Я установил мой pom файл, чтобы попросить Maven скомпилировать мой исходный код с совместимостью версии 1.5 с помощью параметров конфигурации source и target. Вот мой 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>

И у меня есть простой основной класс:

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

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.

Спасибо.

Ответ 1

Из примечания внизу страница компилятора-плагина:

Простое задание целевого параметра не гарантирует, что ваш код действительно работает на JRE с указанной версией. Ловушка - это непреднамеренное использование API-интерфейсов, которые существуют только в более поздних JRE, которые могут привести к сбою вашего кода во время выполнения с ошибкой привязки. Чтобы избежать этой проблемы, вы можете настроить путь к классу загрузки компилятора в соответствии с целевой JRE или использовать плагин Animal Sniffer Maven для проверки того, что ваш код не использует непреднамеренные API

Это означает, что, хотя вы генерируете байт-код на 1,5 уровня, вы все же можете (непреднамеренно) вызвать метод API 1,6. Чтобы отметить эти invalide API-вызовы, используйте плагин, который они упоминают.

Ответ 2

Вам нужно скомпилировать более низкую версию Java, если вы хотите, чтобы она не находила String.isEmpty(). Исходный уровень управляет языковыми уровнями, которые вы можете использовать и не можете использовать, например @Override на интерфейсах, требующих компиляции с исходным уровнем 1.6. Целевой уровень контролирует совместимость байт-кода, который производит компиляция. Ни один из них не имеет ничего общего с доступными API-интерфейсами... все они основаны на пути к классам, который вы используете при создании, который в вашем случае включает Java 1.6.