Maison > Java > javaDidacticiel > Comment spécifier la version Java dans Maven pour les modules enfants : propriétés par rapport au plugin du compilateur ?

Comment spécifier la version Java dans Maven pour les modules enfants : propriétés par rapport au plugin du compilateur ?

Mary-Kate Olsen
Libérer: 2024-11-15 09:52:03
original
594 Les gens l'ont consulté

How do you specify Java version in Maven for child modules: properties vs. compiler plugin?

Spécification de la version Java dans Maven : comparaison des propriétés et du plug-in du compilateur

Introduction

Lorsque vous travaillez avec Maven, spécification de la version Java La version pour les modules enfants dans un projet multi-modules doit être prise en considération. Cet article examine les différences entre la définition de la version Java à l'aide des propriétés Java et le plug-in du compilateur Maven.

Définition de la version Java à l'aide des propriétés

La propriété java.version dans le fichier < propriétés> La section du fichier pom.xml est conçue pour être utilisée avec Spring Boot et définit les versions Java source et cible :

<properties>
    <java.version>1.8</java.version>
</properties>
Copier après la connexion

Définition de la version Java à l'aide du plug-in du compilateur

Le plugin du compilateur Maven propose deux options : spécifier les versions source et cible ou utiliser l'argument "release".

  • Source et cible :
<plugins>
    <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <configuration>
            <source>1.8</source>
            <target>1.8</target>
        </configuration>
    </plugin>
</plugins>
Copier après la connexion

Cela équivaut à utiliser les propriétés suivantes :

<properties>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
</properties>
Copier après la connexion
  • Release :

À partir de Maven 3.6, l'argument release peut être utilisé pour spécifier la version Java :

<properties>
    <maven.compiler.release>9</maven.compiler.release>
</properties>
Copier après la connexion

Différences

  • Source et cible par rapport aux propriétés :Ils sont fonctionnellement équivalents.
  • Version : Dans Maven 3.8 et versions ultérieures, il fournit un moyen standardisé de spécifier les trois versions (source, cible et bootstrap) pour Java 9 et versions ultérieures.
  • Spring Boot : java.version n'est fonctionnel que dans les projets Spring Boot.

Bonnes pratiques

Pour Java 8 et versions antérieures :

  • Utilisez l'une ou l'autre méthode pour spécifier la source et la cible.
  • Si seule la source est spécifiée, Maven peut utiliser une version cible différente en fonction de la source spécifiée.

Pour Java 9 et supérieur :

  • Envisagez d'utiliser l'argument release pour garantir des versions cohérentes pour la source, la cible et le bootstrap.

fork, exécutable et JAVA_HOME

  • Si la version JAVA_HOME JDK est incompatible avec les versions Java spécifiées, spécifiez fork="true" et exécutable dans la configuration du compilateur.
  • Ce n'est pas recommandé pour les versions source et cible doivent dépasser la version du JDK pointée par JAVA_HOME, car le JDK ne peut pas compiler avec une spécification plus récente.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal