Установка -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.