Changements de comportement : toutes les applications

La plate-forme Android 14 apporte des modifications de comportement susceptibles d'affecter votre application. Les modifications de comportement suivantes s'appliquent à toutes les applications lorsqu'elles s'exécutent sur Android 14, peu importe la targetSdkVersion. Vous devez tester votre application, puis la modifier si nécessaire afin de prendre en charge ces modifications, le cas échéant.

Veillez également à consulter la liste des modifications de comportement qui n'affectent que les applications ciblant Android 14.

Fonctionnalité de base

Les alarmes exactes programmées sont refusées par défaut

Les alarmes exactes sont destinées aux notifications ou aux actions intentionnelles de l'utilisateur qui doivent se produire à une heure précise. À partir d'Android 14, l'autorisation SCHEDULE_EXACT_ALARM n'est plus disponible pour la plupart des applications récemment installées sur Android 13 ou version ultérieure. L'autorisation est refusée par défaut.

En savoir plus sur les modifications apportées aux autorisations de planification d'alarmes exactes

Les annonces diffusées en contexte sont mises en file d'attente pendant que les applications sont mises en cache.

Sur Android 14, le système peut placer les diffusions enregistrées en contexte dans une file d'attente pendant que l'application est à l'état "mis en cache" ; Ce comportement est similaire à celui de la mise en file d'attente sous d'Android 12 (niveau d'API 31) pour les transactions de binder asynchrones. Les diffusions déclarées par le fichier manifeste ne sont pas placées en file d'attente, et les applications sont supprimées de l'état mis en cache pour la diffusion.

Lorsque l'application quitte l'état mis en cache, par exemple lorsqu'elle revient au premier plan, le système diffuse toutes les diffusions en file d'attente. Plusieurs instances de certaines diffusions peuvent être fusionnées en une seule diffusion. En fonction d'autres facteurs, les applications peuvent être retirées de l'état mis en cache, et toute application précédemment mise en file d'attente de diffusions.

Les applications ne peuvent fermer que leurs propres processus en arrière-plan

À partir d'Android 14, lorsque votre application appelle killBackgroundProcesses(), seuls les processus en arrière-plan de votre propre application peuvent être fermés par l'API.

Si vous transmettez le nom de package d'une autre application, cette méthode n'a aucun effet sur les processus en arrière-plan de cette application et le message suivant s'affiche dans Logcat :

Invalid packageName: com.example.anotherapp

Votre application ne doit pas utiliser l'API killBackgroundProcesses() ni tenter d'influencer le cycle de vie d'autres applications, même sur des versions d'OS plus anciennes. Android est conçu pour conserver les applications mises en cache en arrière-plan et les fermer automatiquement lorsque le système a besoin de mémoire. Si votre application ferme d'autres applications de manière inutile, elle peut réduire les performances du système et augmenter la consommation de la batterie en exigeant un redémarrage complet de ces applications par la suite, ce qui nécessite beaucoup plus de ressources que la réactivation d'une application existante mise en cache.

La MTU est définie sur 517 pour le premier client GATT qui demande une MTU.

Starting from Android 14, the Android Bluetooth stack more strictly adheres to Version 5.2 of the Bluetooth Core Specification and requests the BLE ATT MTU to 517 bytes when the first GATT client requests an MTU using the BluetoothGatt#requestMtu(int) API, and disregards all subsequent MTU requests on that ACL connection.

To address this change and make your app more robust, consider the following options:

  • Your peripheral device should respond to the Android device's MTU request with a reasonable value that can be accommodated by the peripheral. The final negotiated value will be a minimum of the Android requested value and the remote provided value (for example, min(517, remoteMtu))
    • Implementing this fix could require a firmware update for peripheral
  • Alternatively, limit your GATT characteristic writes based on the minimum between the known supported value of your peripheral and the received MTU change
    • A reminder that you should reduce 5 bytes from the supported size for the headers
    • For example: arrayMaxLength = min(SUPPORTED_MTU, GATT_MAX_ATTR_LEN(517)) - 5

Nouveau motif pouvant entraîner le placement d'une application dans le bucket de mise en veille limité

Android 14 introduit une nouvelle raison pour laquelle une application peut être placée dans le bucket de veille restreint. Les tâches de l'application déclenchent plusieurs fois des erreurs ANR en raison des délais d'inactivité des méthodes onStartJob, onStopJob ou onBind. (Pour en savoir plus sur les modifications apportées à onStartJob et onStopJob, consultez JobScheduler renforce le comportement des rappels et des réseaux.)

Pour savoir si l'application est entrée dans le bucket de veille restreint, nous vous recommandons de vous connecter avec l'API UsageStatsManager.getAppStandbyBucket() lors de l'exécution de la tâche ou UsageStatsManager.queryEventsForSelf() au démarrage de l'application.

mlock limité à 64 Ko

Sous Android 14 (niveau d'API 34) ou version ultérieure, la plate-forme réduit la mémoire maximale pouvant être verrouillée à l'aide de mlock() à 64 Ko par processus. Dans les versions précédentes, la limite était de 64 Mo par processus. Cette restriction favorise une meilleure gestion de la mémoire dans les applications et le système. Pour assurer une plus grande cohérence entre les appareils, Android 14 ajoute un nouveau test CTS pour la nouvelle limite mlock() sur les appareils compatibles.

Le système applique l'utilisation des ressources des applications mises en cache

By design, an app's process is in a cached state when it's moved to the background and no other app process components are running. Such an app process is subject to being killed due to system memory pressure. Any work that Activity instances perform after the onStop() method has been called and returned, while in this state, is unreliable and strongly discouraged.

Android 14 introduces consistency and enforcement to this design. Shortly after an app process enters a cached state, background work is disallowed, until a process component re-enters an active state of the lifecycle.

Apps that use typical framework-supported lifecycle APIs – such as services, JobScheduler, and Jetpack WorkManager – shouldn't be impacted by these changes.

Expérience utilisateur

Modifications apportées à la façon dont les utilisateurs gèrent les notifications qu'ils ne peuvent pas ignorer

If your app shows non-dismissable foreground notifications to users, Android 14 has changed the behavior to allow users to dismiss such notifications.

This change applies to apps that prevent users from dismissing foreground notifications by setting Notification.FLAG_ONGOING_EVENT through Notification.Builder#setOngoing(true) or NotificationCompat.Builder#setOngoing(true). The behavior of FLAG_ONGOING_EVENT has changed to make such notifications actually dismissable by the user.

These kinds of notifications are still non-dismissable in the following conditions:

  • When the phone is locked
  • If the user selects a Clear all notification action (which helps with accidental dismissals)

Also, this new behavior doesn't apply to notifications in the following use cases:

  • CallStyle notifications
  • Device policy controller (DPC) and supporting packages for enterprise
  • Media notifications
  • The default Search Selector package

Amélioration de la visibilité des informations sur la sécurité des données

Pour améliorer la confidentialité des utilisateurs, Android 14 augmente le nombre d'emplacements sur lesquels le système affiche les informations que vous avez déclarées dans le formulaire de la Play Console. Actuellement, les utilisateurs peuvent consulter ces informations dans la section Sécurité des données de la fiche de votre application sur Google Play.

Nous vous invitons à consulter les règles relatives au partage des données de localisation de votre application et à mettre à jour la section Sécurité des données de Google Play de votre application.

Pour en savoir plus, consultez le guide sur la façon dont la visibilité des informations sur la sécurité des données a été améliorée sur Android 14.

Accessibilité

Mise à l'échelle non linéaire de la police à 200 %

À partir d'Android 14, le système prend en charge la mise à l'échelle des polices jusqu'à 200 %, offrant ainsi aux utilisateurs déficients visuels des options d'accessibilité supplémentaires qui respectent les consignes d'accessibilité du contenu Web (WCAG).

Si vous utilisez déjà des unités de pixels mis à l'échelle pour définir la taille du texte, cette modification n'aura probablement pas d'impact notable sur votre application. Toutefois, vous devez effectuer des tests de l'interface utilisateur en activant la taille de police maximale (200 %) pour vous assurer que votre application peut s'adapter à des tailles de police plus importantes sans nuire à la facilité d'utilisation.

Sécurité

Niveau d'API cible installable minimal

Starting with Android 14, apps with a targetSdkVersion lower than 23 can't be installed. Requiring apps to meet these minimum target API level requirements improves security and privacy for users.

Malware often targets older API levels in order to bypass security and privacy protections that have been introduced in newer Android versions. For example, some malware apps use a targetSdkVersion of 22 to avoid being subjected to the runtime permission model introduced in 2015 by Android 6.0 Marshmallow (API level 23). This Android 14 change makes it harder for malware to avoid security and privacy improvements. Attempting to install an app targeting a lower API level will result in an installation failure, with the following message appearing in Logcat:

INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 23, but found 7

On devices upgrading to Android 14, any apps with a targetSdkVersion lower than 23 will remain installed.

If you need to test an app targeting an older API level, use the following ADB command:

adb install --bypass-low-target-sdk-block FILENAME.apk

Les noms de package du propriétaire média peuvent être masqués

Le Media Store accepte les requêtes pour la colonne OWNER_PACKAGE_NAME, qui indique l'application qui a stocké un fichier multimédia spécifique. À partir d'Android 14, cette valeur sera masquée, sauf si au moins l'une des conditions suivantes est remplie :

  • Le nom de package de l'application qui a stocké le fichier multimédia est toujours visible par les autres applications.
  • L'application qui interroge le Media Store demande l'autorisation QUERY_ALL_PACKAGES.

Découvrez comment Android filtre la visibilité des packages à des fins de confidentialité.