Notes de version du plug-in Android Gradle 8.7

Le dépôt JCenter est disponible en lecture seule depuis le 31 mars 2021. Pour en savoir plus, consultez Mise à jour du service JCenter.

Le système de compilation Android Studio est basé sur Gradle, et le plug-in Android Gradle ajoute plusieurs fonctionnalités spécifiques à la compilation d'applications Android. Bien que le plug-in Android Gradle (AGP) soit généralement mis à jour en parallèle d'Android Studio, il (et le reste du système Gradle avec lui) peut fonctionner indépendamment d'Android Studio et être mis à jour séparément.

Cette page explique comment maintenir vos outils Gradle à jour et détaille le contenu des dernières mises à jour. Pour obtenir les notes de version des anciennes versions du plug-in Android Gradle, consultez les notes de version antérieures.

Pour voir les corrections apportées à cette version du plug-in Android Gradle, consultez les problèmes résolus.

Pour un résumé global des modifications importantes à venir dans le plug-in Android Gradle, consultez la feuille de route du plug-in Android Gradle.

Pour savoir comment configurer vos builds Android avec Gradle, consultez les pages suivantes :

Pour en savoir plus sur le système de compilation Gradle, consultez le guide de l'utilisateur Gradle.

Mettre à jour le plug-in Android Gradle

Lorsque vous mettez à jour Android Studio, vous pouvez être invité à installer automatiquement la dernière version disponible du plug-in Android Gradle. Vous pouvez accepter la mise à jour ou indiquer manuellement une version spécifique en fonction des exigences de compilation de votre projet.

Vous pouvez préciser la version du plug-in soit via le menu File > Project Structure > Project (Fichier > Structure du projet > Projet) d'Android Studio, soit via le fichier build.gradle.kts de premier niveau. La version du plug-in s'applique à tous les modules créés dans ce projet Android Studio. L'exemple suivant définit le plug-in sur la version 8.7.0 du fichier build.gradle.kts:

Kotlin

plugins {
    id("com.android.application") version "8.7.0" apply false
    id("com.android.library") version "8.7.0" apply false
    id("org.jetbrains.kotlin.android") version "2.0.20" apply false
}

Groovy

plugins {
    id 'com.android.application' version '8.7.0' apply false
    id 'com.android.library' version '8.7.0' apply false
    id 'org.jetbrains.kotlin.android' version '2.0.20' apply false
}

Attention:N'utilisez pas de dépendances dynamiques comme 'com.android.tools.build:gradle:8.7.+' dans les numéros de version. L'utilisation de cette fonctionnalité peut entraîner des mises à jour inattendues et des problèmes pour résoudre les différences de version.

Si la version du plug-in indiquée n'a pas été téléchargée, Gradle la télécharge la prochaine fois que vous compilez votre projet ou cliquez sur File > Sync Project with Gradle Files (Fichier > Synchroniser le projet avec les fichiers Gradle) dans la barre de menu d'Android Studio.

Mettre à jour Gradle

En mettant à jour Android Studio, vous pouvez également recevoir une invite pour mettre à jour Gradle vers la dernière version disponible. Vous pouvez accepter la mise à jour ou indiquer manuellement une version spécifique en fonction des exigences de compilation de votre projet.

Le tableau suivant indique les versions de Gradle requises pour chaque version du plug-in Android Gradle. Pour optimiser les performances, utilisez la dernière version possible de Gradle et du plug-in.

Version du plug-inVersion minimale requise de Gradle
8,78,9
8,68,7
8,58,7
8,48,6
8,38,4
8.28.2
8.18.0
8.08.0
7.47.5

Anciennes versions

Version du plug-inVersion de Gradle requise
7.37.4
7.27.3.3
7.17.2
7.07.0
4.2.0+6.7.1
4.1.0+6.5+
4.0.0+6.1.1+
3.6.0 à 3.6.45.6.4+
3.5.0 à 3.5.45.4.1+
3.4.0 à 3.4.35.1.1+
3.3.0 à 3.3.34.10.1+
3.2.0 à 3.2.14.6+
3.1.0+4.4+
3.0.0+4.1+
2.3.0+3.3+
2.1.3 à 2.2.32.14.1 à 3.5
2.0.0 à 2.1.22.10 à 2.13
1.5.02.2.1 à 2.13
1.2.0 à 1.3.12.2.1 à 2.9
1.0.0 à 1.1.32.2.1 à 2.3

Vous pouvez indiquer la version de Gradle spécifique soit via le menu File > Project Structure > Project (Fichier > Structure du projet > Projet) d'Android Studio, soit en mettant à jour votre version de Gradle à l'aide de la ligne de commande. La méthode privilégiée consiste à utiliser l'outil de ligne de commande Gradle Wrapper, qui met à jour les scripts gradlew. L'exemple suivant définit la version de Gradle sur la version 8.7 à l'aide de Gradle Wrapper. Notez que vous devez exécuter cette commande deux fois pour mettre à niveau à la fois Gradle et Gradle Wrapper lui-même (pour en savoir plus, consultez Mettre à niveau Gradle Wrapper).

gradle wrapper --gradle-version 8.7

Toutefois, cela peut échouer dans certains cas, par exemple si vous venez de mettre à jour l'AGP et qu'il n'est plus conforme à la version actuelle de Gradle. Dans ce cas, modifiez la référence de distribution Gradle dans le fichier gradle/wrapper/gradle-wrapper.properties. L'exemple suivant définit la version de Gradle sur la version 8.7 dans le fichier gradle-wrapper.properties.

...
distributionUrl = https\://services.gradle.org/distributions/gradle-8.7-bin.zip
...

Compatibilité entre le plug-in Android Gradle et Android Studio

Le système de compilation Android Studio est basé sur Gradle, et le plug-in Android Gradle (AGP) ajoute plusieurs fonctionnalités spécifiques à la compilation d'applications Android. Le tableau suivant indique la version de l'AGP requise pour chaque version d'Android Studio.

Version d'Android Studio Version de l'AGP requise
Ladybug | 2024.2.1 3.2-8.7
Mise à jour groupée Koala | 02/01/2024 3.2-8.6
Koala | 2024.1.1 3.2-8.5
Jellyfish | 2023.3.1 3.2-8.4
Iguana | 2023.2.1 3.2-8.3
Hedgehog | 2023.1.1 3.2-8.2
Giraffe | 2022.3.1 3.2-8.1
Flamingo | 2022.2.1 3.2-8.0

Anciennes versions

Version d'Android Studio Version de l'AGP requise
Electric Eel | 2022.1.1 3.2-7.4
Dolphin | 2021.3.1 3.2-7.3
Chipmunk | 2021.2.1 3.2-7.2
Bumblebee | 2021.1.1 3.2-7.1
Arctic Fox | 2020.3.1 3.1-7.0

Pour en savoir plus sur les nouveautés du plug-in Android Gradle, consultez les notes de version du plug-in Android Gradle.

Versions minimales des outils pour le niveau d'API Android

Il existe des versions minimales d'Android Studio et d'AGP compatibles avec un niveau d'API spécifique. L'utilisation de versions antérieures d'Android Studio ou d'AGP à celles requises par les éléments targetSdk ou compileSdk de votre projet pourrait entraîner des problèmes inattendus. Nous vous recommandons d'utiliser la dernière version preview d'Android Studio et d'AGP pour travailler sur des projets qui ciblent les versions preview de l'OS Android. Vous pouvez installer des versions preview d'Android Studio en plus d'une version stable.

Les versions minimales d'Android Studio et d'AGP sont les suivantes :

Niveau d'API Version minimale d'Android Studio Version minimale d'AGP
Aperçu de Baklava Suricate | 2024.3.1 8.9.0
35 Mise à jour groupée Koala | 2024.2.1 8.6.0
34 Hedgehog | 2023.1.1 8.1.1
33 Flamingo | 2022.2.1 7.2

Modifications par version (novembre 2020)

Mise à jour de la numérotation de version du plug-in Android Gradle (AGP) afin qu'il corresponde plus précisément à l'outil de compilation Gradle sous-jacent.

Modifications importantes :

  • L'AGP utilisera désormais des dénominations sémantiques de versions, et les modifications importantes seront effectuées dans les versions majeures.

  • Une version majeure de l'AGP sera publiée chaque année, en même temps que la version majeure de Gradle.

  • La version 7.0 de l'AGP suivra la version 4.2 et nécessitera une mise à niveau vers la version 7.x de Gradle. Chaque version majeure de l'AGP nécessite une mise à niveau majeure de version dans l'outil Gradle sous-jacent.

  • Les API seront abandonnées environ un an à l'avance, et les fonctionnalités de remplacement seront disponibles simultanément. Les API obsolètes seront supprimées environ un an plus tard lors de la mise à jour majeure suivante.

Compatibilité

Le niveau d'API maximal compatible avec le plug-in Android Gradle 8.6 est le niveau d'API 34. Voici d'autres informations sur la compatibilité:

Version minimale Version par défaut Notes
"Gradle" 8,9 8,9 "Pour en savoir plus, consultez Mettre à jour Gradle."
Build Tools SDK 34.0.0 34.0.0 Installez ou configurez des Build Tools SDK.
NDK N/A 27.0.12077973 "Installez ou configurez une autre version du NDK."
JDK 17 17 "Pour en savoir plus, consultez Définir la version du JDK."

Changement de comportement de lint

À partir du plug-in Android Gradle 8.7.0-alpha08, si une LintError est détectée lors de l'exécution de lint à l'aide de Gradle, la tâche d'analyse lint génère une exception. Cette modification empêche les erreurs rares d'être mises en cache dans le cache de compilation.

Malheureusement, ce changement interrompt les compilations pour les projets comportant des instances LintError authentiques dans leurs fichiers de référence lint. Le message d'erreur contient des informations sur les vérifications lint à l'origine du problème. Dans certains cas, la mise à jour de la dépendance de bibliothèque correspondante peut résoudre le problème. Si ce n'est pas le cas, vous pouvez désactiver la vérification lint problématique jusqu'à ce que l'auteur de la bibliothèque la corrige.

Problèmes résolus

Plug-in Android Gradle 8.7.0

Problèmes résolus
Plug-in Android Gradle
AGP doit indiquer qu'il est compatible avec l'API 35 qui est sur le point d'être publiée.
AGP 8.5: de nombreuses tâches "mergeDebugResources" sont exécutées, ce qui ralentit les compilations
Définir ndk 27 comme NDK par défaut dans AGP.
AGP doit indiquer qu'il est compatible avec l'API 35 qui est sur le point d'être publiée.
AGP doit indiquer qu'il est compatible avec l'API 35 qui est sur le point d'être publiée.
Échec de l'exécution de lint Android avec NoSuchFileException
BuildType#initWith copie le bloc de post-traitement, mais la configuration ProGuard n'est pas appliquée
Impossible de fusionner pour les balises foregroundServiceType
Échec de l'exécution de lint Android avec NoSuchFileException
Lint
Lint doit rechercher les objets non valides utilisés comme ViewGroups
"android:host est manquant" pour les URI avec un hôte nul
Incompatibilité de KtAnalysisSessionProvider avec les vérifications lint introduite dans 8.7.0-alpha04
"Faux positif" WrongConstant lors de l'utilisation de PackageManager.ResolveInfoFlags.of avec Kotlin

Plug-in Android Gradle 8.7.1

Problèmes résolus
Plug-in Android Gradle
Les documents agp contiennent de nombreux éléments à définir.
Lint
AGP 8.6.1 : régression : échec de lint WrongConstant lors de l'utilisation de [Int].toLong() dans un @LongDef en Kotlin
Erreur lint "Au moins un hôte doit être spécifié" lors du paramétrage du schéma de filtre d'intent http ou https

Plug-in Android Gradle 8.7.2

Problèmes résolus
Lint
AGP 8.7.0 : faux positif de lint RestrictedApi sur NavOptionsBuilder.popUpTo
Réducteur de code (R8)
[R8 8.6.27] L'implémentation de la méthode a été remplacée par "throw null"
Les fichiers ProGuard Android par défaut génèrent un avertissement lorsqu'ils sont utilisés avec la version actuelle de R8
MissingStartupProfileItemsDiagnostic plante le client Gradle avec une erreur de manque de mémoire si le message est trop volumineux

Plug-in Android Gradle 8.7.3

Problèmes résolus
Lint
De nombreux avertissements de méthode d'API d'analyse manquants lors de l'exécution de lint
Vérification lint faussement positive android.permission.SCHEDULE_EXACT_ALARM n'est accordée qu'aux applications système